安卓开发——做一个能定时唤起其他APP的闹钟程序

北战南征 提交于 2020-08-14 13:03:59

一、准备工作:

要让一个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:gravity="center"
        android:textColor="#ffffff"
        />
    <TextView
        android:id="@+id/qq_tv"
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:text="启动QQ闹钟"
        android:textSize="16sp"
        android:gravity="center"
        android:textColor="#000000"
        />
    <View
        android:layout_width="match_parent"
        android:layout_height="0.5dp"
        android:background="#ff00ff"
        />

    <TextView
        android:id="@+id/weibo_tv"
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:text="启动微博闹钟"
        android:textSize="16sp"
        android:gravity="center"
        android:textColor="#000000"
        />
    <View
        android:layout_width="match_parent"
        android:layout_height="0.5dp"
        android:background="#ff00ff"
        />

    <TextView
        android:id="@+id/wechat_tv"
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:text="启动微信闹钟"
        android:textSize="16sp"
        android:gravity="center"
        android:textColor="#000000"
        />
    <View
        android:layout_width="match_parent"
        android:layout_height="0.5dp"
        android:background="#ff00ff"
        />

</LinearLayout>

(2)界面截图

在这里插入图片描述

(3)后台Java代码

TextView的点击事件会先检测手机中是否有安装对应的app,没有安装的话如下图所示

package com.clock.app;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.TextView;
import android.widget.Toast;

public class MainActivity extends Activity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        TextView QQTv = findViewById(R.id.qq_tv);
        TextView weiboTv = findViewById(R.id.weibo_tv);
        TextView wechatTv = findViewById(R.id.wechat_tv);
        QQTv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                if(AppUtils.checkPackInfo(MainActivity.this,"com.tencent.mobileqq")) {
                    Intent intent = new Intent(MainActivity.this, ClockActivity.class);
                    intent.putExtra("type", 1);
                    startActivity(intent);
                }else {
                    Toast.makeText(MainActivity.this,"设备没有安装QQ",Toast.LENGTH_SHORT).show();
                }
            }
        });
        weiboTv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                if(AppUtils.checkPackInfo(MainActivity.this,"com.sina.weibo")) {
                    Intent intent = new Intent(MainActivity.this, ClockActivity.class);
                    intent.putExtra("type", 2);
                    startActivity(intent);
                }else {
                    Toast.makeText(MainActivity.this,"设备没有安装微博",Toast.LENGTH_SHORT).show();
                }
            }
        });
        wechatTv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                if(AppUtils.checkPackInfo(MainActivity.this,"com.tencent.mm")) {
                    Intent intent = new Intent(MainActivity.this, ClockActivity.class);
                    intent.putExtra("type", 3);
                    startActivity(intent);
                }else {
                    Toast.makeText(MainActivity.this,"设备没有安装微信",Toast.LENGTH_SHORT).show();
                }
            }
        });
    }
}

这里是用模拟器运行的,模拟器上只安装了QQ,所以如果点击其他两个TextView会提示“设备没有安装微信/微博”
在这里插入图片描述
在这里插入图片描述

四、闹钟界面:

(1)XML布局代码

上面的TextView是在选择不同应用的闹钟,文字会发生改变的标题;
下面的TextView是在设置好闹钟后,显示闹钟唤起功能启动的时间。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
    
     <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:background="#ff0000"
        android:orientation="horizontal" >
         
        <TextView
            android:id="@+id/title_tv"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:gravity="center"
            android:text="闹钟定时"
            android:textColor="#FFFFFFFF"
            android:textSize="18sp"
            android:textStyle="bold" />

      
    </RelativeLayout>
    
   <TextView
            android:id="@+id/content_tv"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:gravity="center"
            android:text="闹钟定时"
            android:lineSpacingExtra="8dp"
            android:textColor="#000000"
            android:textSize="18sp"
            android:textStyle="bold" />

</LinearLayout>

(2)界面截图

这里我们点击第一个TextView,启动QQ闹钟,会跳转到设置闹钟的界面。可以调时钟设置时间,也可以直接输入时间的数值。
在这里插入图片描述
在这里插入图片描述

(3)后台Java代码

闹钟选用的是Android Studio自带的TimePicker组件,这在很多app上都有使用,比如这里知乎设置自动切换夜间模式的时间节点的地方。
在这里插入图片描述
在这里插入图片描述
TimePicker组件需要说明的地方已在代码中写下注释
代码:



package com.clock.app;

import android.app.Activity;
import android.app.AlarmManager;
import android.app.Dialog;
import android.app.PendingIntent;
import android.app.TimePickerDialog;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.widget.TextView;
import android.widget.TimePicker;

import java.text.SimpleDateFormat;
import java.util.Calendar;


public class ClockActivity extends Activity {
    AlarmManager alarmManager = null;
    Calendar calendar = Calendar.getInstance();
    TextView title_tv,timeTv;
    private int type = 0;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_clock);
        title_tv = findViewById(R.id.title_tv);
        timeTv = findViewById(R.id.content_tv);
        type  = getIntent().getIntExtra("type",1);
        if(type == 1){
            title_tv.setText("拉起QQ闹钟");
        }else if(type == 2){
            title_tv.setText("拉起微博闹钟");
        }else if(type == 3){
            title_tv.setText("拉起微信闹钟");
        }
        alarmManager=(AlarmManager)getSystemService(Context.ALARM_SERVICE);
        setClock();
    }

    private void setClock(){
        Dialog dialog = new TimePickerDialog(ClockActivity.this,new TimePickerDialog.OnTimeSetListener() {

            @Override
            public void onTimeSet(TimePicker view, int hourOfDay, int minute) {
                // TODO Auto-generated method stub
                Calendar c=Calendar.getInstance();              //获取日期对象
                c.setTimeInMillis(System.currentTimeMillis());  //设置Calendar对象
                c.set(Calendar.HOUR_OF_DAY, hourOfDay);         //设置闹钟小时数
                c.set(Calendar.MINUTE, minute);                 //设置闹钟的分钟数
                c.set(Calendar.SECOND, 0);                      //设置闹钟的秒数
                c.set(Calendar.MILLISECOND, 0);                 //设置闹钟的毫秒数

                String realTime = new SimpleDateFormat("HH:mm").format(c.getTime());
                timeTv.setText(realTime);

                Intent intent = new Intent(ClockActivity.this, AlarmReceiver.class);
                intent.putExtra("type", type);
                // intent.setFlags(Integer.parseInt(id));//作为取消时候的标识
                PendingIntent pi = PendingIntent.getBroadcast(ClockActivity.this, 0,
                        intent, PendingIntent.FLAG_CANCEL_CURRENT);    //创建PendingIntent

                //设置一次性闹钟,第一个参数表示闹钟类型,第二个参数表示闹钟执行时间,第三个参数表示闹钟响应动作。
                if(c.getTimeInMillis() < System.currentTimeMillis()){
                    Log.i("clock", "设置时间要推迟24小时,不然立刻会响");
                    alarmManager.set(AlarmManager.RTC_WAKEUP, c.getTimeInMillis()+24*60*60*1000, pi);
                }else{
                    alarmManager.set(AlarmManager.RTC_WAKEUP, c.getTimeInMillis(), pi);        //设置闹钟,当前时间就唤醒
                }

            }
        },calendar.get(Calendar.HOUR_OF_DAY),
                calendar.get(Calendar.MINUTE),
                false);
        dialog.show();

    }
}

五、运行测试:

(1)打开闹钟app,点击启动QQ闹钟

在这里插入图片描述

(2)设置闹钟时间

这里安卓手机模拟器的时间是下午3:44,把闹钟时间定为一分钟后——3:45
在这里插入图片描述

(3)闹钟设置成功,等待到达指定时间

在这里插入图片描述

(4)QQ成功按时被唤起

在这里插入图片描述

(5)把Android工程导出成apk在自己手机上安装成功运行

在这里插入图片描述
在这里插入图片描述

作者:赵昊阳
原文地址:https://blog.csdn.net/joe337347889/article/details/106594221

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!