Android0908<十三>(部分Service、 ContentProvider、 BroadcastReceiver)

ContentProvider

内容提供器(ContentProvider)主要用于不同的应用程序之间实现数据共享的功能

要访问共享的数据,就一定要借助ContentResolver类,可以通过getContentResolver()方法或得该类的实例,通过这个方法提供的方法可以对共享的数据进行增删改查,ContentProvider中的增删改查方法都不接收表名参数而是通过一个Uri参数代替,这个参数称为内容的URI。内容URI由两部分组成,权限(authority)和路径(path)。权限用于对不同的应用程序作区分,用包名命名权限,例如包名为:com.example.app,那么程序对应的权限名称为com.example.app.provider

resolver = getContentResolver();
                Uri uri= ContactsContract.CommonDataKinds.Phone.CONTENT_URI;
                Cursor cursor=resolver.query(uri,new String[]{ContactsContract.CommonDataKinds.Phone.NUMBER,
                        ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME},null,null,null);
                cursor.moveToFirst();

例如想要访问电话薄里的联系人信息,就需要声明权限,就需要在AndroidManifest.XML中增加一条代码如下:

    <uses-permission android:name="android.permission.READ_CONTACTS"/>

还有在ContentResolver的query()方法来查询系统的联系人数据。传入的参数ContactsContract.CommonDataKinds.Phone类已经封装好了,提供了一个.CONTENT_URI常量,联系人名字对应的常量是
ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME,联系人手机号对应的常量是ContactsContract.CommonDataKinds.Phone.NUMBER

具体的实例:ContentResolve.java

package com.example.administrator.controlapplication;

import android.app.Activity;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.provider.ContactsContract;
import android.util.Log;
import android.view.View;
import android.widget.Button;

/**
 * Created by Administrator on 2015/9/8.
 */
public class ContentResolver extends Activity{
    private Button btn_read;
    private android.content.ContentResolver resolver;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_contentresolver);
        btn_read= (Button) findViewById(R.id.readfriends);
        btn_read.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                resolver = getContentResolver();
                Uri uri= ContactsContract.CommonDataKinds.Phone.CONTENT_URI;
                Cursor cursor=resolver.query(uri,new String[]{ContactsContract.CommonDataKinds.Phone.NUMBER,
                        ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME},null,null,null);
                cursor.moveToFirst();
                while(!cursor.isAfterLast()){
                    String []names=cursor.getColumnNames();
                    StringBuffer buffer=new StringBuffer();
                    for(String name:names){
                        String value=cursor.getString(cursor.getColumnIndex(name));
                        buffer.append("字段名"+name+"  字段值"+value);
                    }
                    Log.d("联系人",""+buffer);
                    cursor.moveToNext();
                }
            }
        });
    }
}

这里写图片描述
这里写图片描述
这里写图片描述

BroadcastReceiver

BroadcastReceiver是一种广播接收器
这里写图片描述
这里写图片描述
广播接收器需要在要接受的广播进行注册,才能在广播发出时,广播接收器能够接受到广播,注册广播分为两种,在代码中注册和在
AndroidManifest.xml中注册,前者是动态注册,后者是静态注册

静态的注册广播

首先新建一个简单的继承于BroadcastReceiver的类,如下:

public class BroadcastReceiverActivity extends BroadcastReceiver{
    @Override
    public void onReceive(Context context, Intent intent) {
        Toast.makeText(context,"我接收到了广播",Toast.LENGTH_SHORT).show();
    }
}

然后再AndroidManifest.xml中< application>标签中添加一个新的标签< receiver>,所有的静态的注册广播接收器都在这里,通过一个< android:name>来制定注册拿一个广播接收器,然后在< infent-filter>标签里加入想要加入的广播就行了,如下:

<receiver android:name=".BroadcastReceiverActivity">
            <intent-filter>
                <action android:name="com.myreceiver.test"></action>
                <action android:name="android.net.conn.CONNECTIVITY_CHANGE"></action>
                <action android:name="android.intent.action.PACKAGE_REMOVED"></action>
                </intent-filter>
        </receiver>
动态的注册广播

动态的注册广播,在代码里实现,创建一个IntentFilter和BroadcastReceiverActivity的实例,调用registerReceiver(),然后将这两个实例对象传进去

 mBroadcast=new BroadcastReceiverActivity();
        IntentFilter filter=new IntentFilter();
        filter.addAction("com.myreceiver.test");
        registerReceiver(mBroadcast,filter);

动态注册的广播接收器一定都要取消注册才行,要在onDestroy()中通过调用unregisterReceiver()方法来实现。

 @Override
    protected void onDestroy() {
        super.onDestroy();
        unregisterReceiver(mBroadcast);
    }

在AndroidManifest.xml中加入

<receiver android:name=".BroadcastReceiverActivity">
            <intent-filter>  
                <action android:name="android.net.conn.CONNECTIVITY_CHANGE"></action>
                <action android:name="android.intent.action.PACKAGE_REMOVED"></action>
                </intent-filter>
        </receiver>
自定义的广播MainActivity.java
public class MainActivity extends Activity {
    private Button btn_receiver;
    private android.content.ContentResolver resolver;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        btn_receiver= (Button) findViewById(R.id.receiver);
        btn_receiver.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent=new Intent();
                intent.setAction("com.myreceiver.test");
                sendBroadcast(intent);
            }
        });  
}

BroadcastReceiverActivity.java

public class BroadcastReceiverActivity extends BroadcastReceiver{
    @Override
    public void onReceive(Context context, Intent intent) {
        Toast.makeText(context,"我接收到了广播",Toast.LENGTH_SHORT).show();
    }
}

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.administrator.controlapplication" >
    <uses-permission android:name="android.permission.READ_CONTACTS"></uses-permission>
    <application
        android:allowBackup="true"
        android:icon="@mipmap/youtube_ico"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity
            android:name=".ContentResolver"
            android:label="ContentResolver" >
            </activity>
        <receiver android:name=".BroadcastReceiverActivity">
            <intent-filter>
                <action android:name="com.myreceiver.test"></action>            
                </intent-filter>
        </receiver>

    </application>

</manifest

这里写图片描述

简单地设置闹钟

利用广播机制可以简单地设置闹钟,可以通过getBroadcast(Context context, int requestCode, Intent intent, int flags)从系统取得一个用于向BroadcastReceiver的Intent广播的PendingIntent对象
1、context 将在这个PendingIntent 的内容context 进行广播
2、requestCode 发送端的私人请求码(目前未使用)。
3、intent 被广播的Intent
4、flags 可以
flag_one_shot,flag_no_create,flag_cancel_current,flag_update_current,或任何的旗帜支持byintent。fillin()控制指定部分的意图,可以提供实际发生时发送。
FLAG_CANCEL_CURRENT:如果当前系统中已经存在一个相同的PendingIntent对象,那么就将先将已有的PendingIntent取消,然后重新生成一个PendingIntent对象。

调用AlarmManager的setRepeating()方法设置闹钟的显示时间

type:表示警报类型,一般可以取的值是AlarmManager.RTC和AlarmManager.RTC_WAKEUP。如果将type参数值设为AlarmManager.RTC,表示是一个正常的定时器,如果将type参数值设为AlarmManager.RTC_WAKEUP,除了有定时器的功能外,还会发出警报声(例如,响铃、震动)。

triggerAtTime:第1次运行时要等待的时间,也就是执行延迟时间,单位是毫秒。

interval:表示执行的时间间隔,单位是毫秒。

operation:一个PendingIntent对象,表示到时间后要执行的操作。PendingIntent与Intent类似,可以封装Activity、BroadcastReceiver和Service。但与Intent不同的是,PendingIntent可以脱离应用程序而存在。

PendingIntent pendingIntent=PendingIntent.getBroadcast(getApplication(),0x23,intent,PendingIntent.FLAG_UPDATE_CURRENT);
                mAlarmManager.setRepeating(AlarmManager.RTC_WAKEUP,System.currentTimeMillis()+5000,3000,pendingIntent);

当然需要不想闹钟一直响,就需要一个取消闹钟的方法,只需调用AlarmManager的cancel()方法即可。

 Intent intent=new Intent();
                intent.setAction("com.myreceiver.test");
                PendingIntent pendingIntent=PendingIntent.getBroadcast(getApplication(),0x23,intent,PendingIntent.FLAG_UPDATE_CURRENT);
                mAlarmManager.cancel(pendingIntent);

BroadcastReceiverActivity .java

public class BroadcastReceiverActivity extends BroadcastReceiver{
    @Override
    public void onReceive(Context context, Intent intent) {
        Toast.makeText(context,"闹钟响了,该起床了",Toast.LENGTH_SHORT).show();
    }
}

这里写图片描述

Service

这里写图片描述

Service需要在AndroidManifest.xml中进行注册

<service android:name=".MyService"></service>

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.administrator.controlapplication" >
    <uses-permission android:name="android.permission.READ_CONTACTS"></uses-permission>
    <application
        android:allowBackup="true"
        android:icon="@mipmap/youtube_ico"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity
            android:name=".ContentResolver"
            android:label="ContentResolver" >
            </activity>
        <receiver android:name=".BroadcastReceiverActivity">
            <intent-filter>
                <!--<action android:name="com.myreceiver.test"></action>-->
                <action android:name="android.net.conn.CONNECTIVITY_CHANGE"></action>
                <action android:name="android.intent.action.PACKAGE_REMOVED"></action>
                </intent-filter>
        </receiver>
        <service android:name=".MyService"></service>
        <service android:name=".MyIntentService"></service>
    </application>
</manifest>

首先要写一个继承于Service的类,
MyService.java

public class MyService extends Service{
    @Nullable
    @Override
    public IBinder onBind(Intent intent) {
        return null;
    }

    @Override
    public void onCreate() {
        super.onCreate();
        Log.d("运行到了","onCreate");
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
        Log.d("运行到了","onDestroy");
    }

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        Log.d("运行到了","onStartCommand");
        return super.onStartCommand(intent, flags, startId);
    }
}

MainActivity.java

public class MainActivity extends Activity {
    private Button btn_start_service;
    private Button btn_stop_service;   
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);      
        btn_start_service= (Button) findViewById(R.id.start_service);
        btn_start_service.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent=new Intent(getApplicationContext(),MyService.class);
                startService(intent);
            }
        });
        btn_stop_service= (Button) findViewById(R.id.stop_service);
        btn_stop_service.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent=new Intent(getApplicationContext(),MyService.class);
                stopService(intent);
            }
        });
    }

BroadcastReceiverActivity.java

public class BroadcastReceiverActivity extends BroadcastReceiver{
    @Override
    public void onReceive(Context context, Intent intent) {
        Toast.makeText(context,"确定要删除了此应用吗",Toast.LENGTH_SHORT).show();
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值