做一个能定时唤起其他APP的闹钟程序
一、准备工作:
要让一个app唤起另一个app,首先要做的是要知道被唤起app的包名,一般在手机的 文件管理->Android->data就能看到已安装的app的包名了。
比如这里的com.baidu.BaiduMap和com.baidu.netdisk对应的就是“百度地图”和“百度网盘”这两个app。
本次博客我将用QQ、微信和新浪微博这三个app作为闹钟唤起的例子,想用闹钟唤起其他app,只需要把程序里的包名和相关位置的描述性文字进行修改,就能实现了。
QQapp的包名:com.tencent.mobileqq
微信app的包名:com.tencent.mm
微博app的包名:com.sina.weibo
二、从一个app唤起其他app功能的核心代码:
这里是先用getPackageManager()获取设备应用信息,再用getLaunchIntentForPackage(packname)唤起传入包名packname相对应的app。
package com.clock.app;
import android.content.Context;
import android.content.Intent;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
public class AppUtils {
public static void startApp(Context context, String packname) {
PackageManager packageManager = context.getPackageManager();//获取设备应用信息
Intent intent = packageManager.getLaunchIntentForPackage(packname);//唤起app
context.startActivity(intent);
}
// 检查包名是否存在
public static boolean checkPackInfo(Context context, String packname) {
PackageInfo packageInfo = null;
try {
packageInfo = context.getPackageManager().getPackageInfo(packname, 0);
} catch (PackageManager.NameNotFoundException e) {
e.printStackTrace();
}
return packageInfo != null;
}
}
再使用AppUtils类从AlarmReceiver用包名唤起对应app
package com.clock.app;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
public class AlarmReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
int type = intent.getIntExtra("type",1);
if(type == 1){
AppUtils.startApp(context,"com.tencent.mobileqq");
}else if(type == 2){
AppUtils.startApp(context,"com.sina.weibo");
}else if(type == 3){
AppUtils.startApp(context,"com.tencent.mm");
}
}
}
三、主页面:
(1)XML布局代码
这里要用到的是TextView的点击事件,所以给每个要唤起的app都定义一个TextView
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity">
<TextView
android:layout_width="match_parent"
android:layout_height="50dp"
android:background="#ff0000"
android:text="主页"
android:textSize="16sp"
android