android 中PendingIntent 和AlarmManager

想要让广播(服务,比如轮询)一直执行想要的操作怎么办呢,可以考虑使用PengdingIntent 和AlarmManager的搭配
在MainActivity中,编写自己想要实现的意图:

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Intent intent = new Intent("ELITOR_CLOCK");
        intent.putExtra("msg","我获取到了信息");
        //使用pendingIntent对Intent进行封装,发送给广播接受者
        PendingIntent pendingIntent = PendingIntent.getBroadcast(this,0,intent,0);
        //使用AlarmManager进行时间的管理,是系统服务不能new
        AlarmManager am = (AlarmManager) getSystemService(ALARM_SERVICE);
        //设置要传递的pendingIntent 
         am.setRepeating(AlarmManager.RTC_WAKEUP,System.currentTimeMillis(),5*1000,pendingIntent);
    }

根据注释内容已经可以看明白了,PendingIntent其实就是对Intent的封装,将其他的信息用一个大的PendingIntnet去传递,在PendingIntent中利用了AlarmManager的特性,定时的发送意图,那发送的意图,肯定要去处理意图,这里用一个广播去处理

public class MyRecevier extends BroadcastReceiver {
    @Override
    public void onReceive(Context context, Intent intent) {

        String message = intent.getStringExtra("msg");
        String action = intent.getAction();
        Toast.makeText(context,message+"action:"+action,Toast.LENGTH_SHORT).show();

    }
}

重写Receiver方法,将数据从intent中取出来
记得要在AndroidManifest.xml中进行过滤才能够在Receiver中获取到数据(拦截到广播)

<receiver android:name=".MyRecevier" >
            <intent-filter >
                <action android:name="ELITOR_CLOCK"/>
                intent-filter>
    receiver>

这样就可以每隔一段时间在手机出现土司的效果了,也可以让后台的服务去执行操作

你可能感兴趣的:(android,android)