AndroidAndroid开发程序员

05广播-发送自定义广播及本地广播

2018-03-19  本文已影响46人  何惧l

广播主要分两种类型:标准广播和有序广播

发送标准广播

  1. 首先定义一个广播接收器来接收此广播,新建一个MyBroadcastReceiver

public class MyBroadcastReceiver extends BroadcastReceiver {

    @Override
    public void onReceive(Context context, Intent intent) {
        Toast.makeText(context,"received in MyBroadcastReceiver",Toast.LENGTH_LONG).show();
    }
}

  1. 在AndroidManifest.xml中对这个广播接收器进行修改
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.md.bb">

    ...

        <receiver
            android:name=".MyBroadcastReceiver"
            android:enabled="true"
            android:exported="true">
            <intent-filter>
                <action android:name="com.example.md.MY_BROADCAST"/>
            </intent-filter>
        </receiver>
    </application>

</manifest>

  1. 修改Activity_main.xml中的代码
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">

    <Button
        android:id="@+id/button"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text=" send Broadcast"/>
    
</LinearLayout>

  1. 修改MainActivity中的代码


public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main_activity);

        Button button = (Button)findViewById(R.id.button);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                // 我们自定义的广播
                Intent intent = new Intent("com.example.md.MY_BROADCAST");
                // 发送出去
                sendBroadcast(intent);
            }
        });
    }
}


发送有序广播

广播是一种可以跨进程的通信,此前在我们程序内发出的广播,其他的应用也是可以接收到的,再新建一个项目,用于接收上面的自定义广播

  1. 新建AntotherBroadcastReceive

public class AntotherBroadcastReceive extends BroadcastReceiver {

    @Override
    public void onReceive(Context context, Intent intent) {
        Toast.makeText(context,"received in AntotherBroadcastReceive",Toast.LENGTH_SHORT).show();
         Log.d("aaaaaaaaaa","aaaaaaaaaaaaaa");

    }
}


  1. 在AndroidManifest.xml中对这个广播进行修改
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.md.b2">
    <application
        ...
    
        <receiver
            android:name=".AntotherBroadcastReceive"
            android:enabled="true"
            android:exported="true">
            <intent-filter>
                <!--这里是我们自定义的广播-->
                <action android:name="com.example.md.MY_BROADCAST"/>
            </intent-filter>
        </receiver>
    </application>

</manifest>

  1. 发送有序广播,还是在第一个项目中,在MainActivity中
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main_activity);

        Button button_1 = (Button)findViewById(R.id.button_1);
        button_1.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {

                // 我们自定义的广播
                Intent intent = new Intent("com.example.md.MY_BROADCAST");
                // 添加进来
                //sendBroadcast(intent);
                sendOrderedBroadcast(intent,null);
            }

        });

    }

...
 <receiver
            android:name=".MyBroadcastReceiver"
            android:enabled="true"
            android:exported="true">
            <intent-filter android:priority="100">
                <action android:name="com.example.md.MY_BROADCAST"/>
            </intent-filter>
        </receiver>



public class MyBroadcastReceiver extends BroadcastReceiver {

    @Override
    public void onReceive(Context context, Intent intent) {
        Toast.makeText(context,"received in MyBroadcastReceiver",Toast.LENGTH_SHORT).show();
        abortBroadcast();
    }
}

本地广播

前面使用的发送和接收的广播都是系统的全局广播,就是发出的和接收的广播都可以被其他程序接收,这个时候安全性就下降了,这个时候,我们使用本地广播,就是
发出的广播只能够在应用程序的内部使用,并且广播接收器也只能接收来自本应用内部的广播

  1. 在MainActivity中修改代码,只要就是使用了LocalBroadcastManager来对广播进行管理

public class MainActivity extends AppCompatActivity {

    private IntentFilter intentFilter;

    private LocalReceiver localReceiver;
    private LocalBroadcastManager localBroadcastManager;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main_activity);

        // 获取实例
        localBroadcastManager = LocalBroadcastManager.getInstance(this);

        Button button_1 = (Button)findViewById(R.id.button_1);
        button_1.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                // 我们自定义的广播
                Intent intent = new Intent("com.example.md.LOCAL_BROADCAST");
                //发送自定义广播
                localBroadcastManager.sendBroadcast(intent);
            }

        });


//        // 创建一个实例
        intentFilter = new IntentFilter();
//        // 添加一个action,
        intentFilter.addAction("com.example.md.LOCAL_BROADCAST");
        localReceiver = new LocalReceiver();
        //注册的是本地的广播接收器
        localBroadcastManager.registerReceiver(localReceiver,intentFilter);

    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        // 动态注册的广播需要注册
        localBroadcastManager.unregisterReceiver(localReceiver);
    }

    
    class LocalReceiver extends BroadcastReceiver{
        @Override
        public void onReceive(Context context, Intent intent) {
            Toast.makeText(context,"received local broadcast",Toast.LENGTH_SHORT).show();
        }
    }

}


  1. 本地广播是无法通过静态注册的方式来接收的,这是因为静态的注册主要就是为了让程序在没有启动的情况下也能接收到广播,而发送本地广播是在程序启动的情况下
  2. 本地广播的优势
    • 可以明确的知道正在发送的广播是什么,不用担心机密数据的泄漏
    • 其他程序的广播也无法将广播发送到我们的程序内部,不用担心安全漏洞问题
    • 发送本地广播比发系统广播效率高
上一篇 下一篇

猜你喜欢

热点阅读