简体   繁体   English

Android - 广播接收器不记录消息

[英]Android - Broadcast Receiver not logging messages

I have a service which contains a Broadcast Receiver that looks for Wi-Fi state change and makes a toast when enabled or disabled. 我有一个service ,其中包含一个Broadcast Receiver ,用于查找Wi-Fi状态更改并在启用或禁用时进行祝酒。 But, my code does not toast the wi-fi state change messages though it toasts the messages related to service create, start and destroy. 但是,我的代码不会干扰Wi-Fi状态更改消息,尽管它会提供与服务创建,启动和销毁相关的消息。

WLANService.java

    public class WLANService extends Service {
    public WLANService() {
    }

    @Override
    public IBinder onBind(Intent intent) {
        throw new UnsupportedOperationException("Not yet implemented");
    }

    @Override
    public void onCreate() {
        super.onCreate();
        Toast.makeText(this, "Service Created!", Toast.LENGTH_LONG).show();
    }

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {

        int state = 0;
        String message = intent.getStringExtra("message");
        Toast.makeText(this, "Service Started & " + message, Toast.LENGTH_LONG).show();

        BroadcastReceiver broadcastReceiver = new BroadcastReceiver() {
            @Override
            public void onReceive(Context context, Intent intent) {
                WifiManager wifiManager = (WifiManager) getApplicationContext().getSystemService(Context.WIFI_SERVICE);
                if(wifiManager.isWifiEnabled()) {
                    Log.i("Wi-Fi-State", "Wi-Fi is On!");
                }else {
                    Log.i("Wi-Fi-State", "Wi-Fi is Off!");
                }
            }
        };
        return START_STICKY;
    }

    @Override
    public void onDestroy() {
        Toast.makeText(this, "Service Destroyed!", Toast.LENGTH_LONG).show();
    }
}

MainActivity.java

    public class MainActivity extends AppCompatActivity {

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

    public void startTheService(View v) {
        Intent intent = new Intent(this, WLANService.class);
        intent.putExtra("message", "I got your message!");
        startService(intent);
    }

    public void stopTheService(View v) {
        stopService(new Intent(this, WLANService.class));
    }
}

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.wifiservice">

    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

        <service
            android:name=".WLANService"
            android:enabled="true"
            android:exported="false">
        </service>
    </application>

</manifest>

You could do something like this: 你可以这样做:

public class WLANService extends Service {
    private final BroadcastReceiver receiver = new BroadcastReceiver() {
        @Override
        public void onReceive(Context context, Intent intent) {
            NetworkInfo info = intent.getParcelableExtra(WifiManager.EXTRA_NETWORK_INFO);
            boolean connected = info.isConnected();
            if(connected) {
                Toast.makeText(context, "WIFI CONNECTED!", Toast.LENGTH_LONG).show();
                Log.i("Wi-Fi-State", "Wi-Fi is On!");
            } else {
                Toast.makeText(context, "WIFI DISCONNECTED!", Toast.LENGTH_LONG).show();
                Log.i("Wi-Fi-State", "Wi-Fi is Off!");
            }
        }
    }

    public WLANService() {
    }

    @Override
    public IBinder onBind(Intent intent) {
        return null;
    }

    @Override
    public void onCreate() {
        super.onCreate();
        Toast.makeText(this, "Service Created!", Toast.LENGTH_LONG).show();
    }

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        // registering your receiver
        registerReceiver(receiver, new IntentFilter(WifiManager.NETWORK_STATE_CHANGED_ACTION));
        return START_STICKY;
    }
}

MainActivity: 主要活动:

public class MainActivity extends AppCompatActivity {

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

        // starting your Service
        startTheService();
    }

    public void startTheService() {
        Intent intent = new Intent(this, WLANService.class);
        intent.putExtra("message", "I got your message!");
        startService(intent);
    }
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM