- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我的广播接收器监听 WiFi ssid 更改,如果 ssid 更改,它返回 boolean 值 WifiChanged true。我在另一个 Activity 中检查这个 boolean 值,该 Activity 根据返回的值更改列表,无论它是真还是假。默认情况下 boolean 值是 false。
我有意更改应触发广播接收器将 boolean 值返回为 true 并相应地设置列表的 wifi,但实际发生的是我的列表根据 boolean 值 false 更改,因为广播接收器需要一段时间才能返回值(value)。在下面的日志中,您可以看到 boolean 值为 false,大约 0.58 秒后 ssid 发生变化。到时候就晚了
08-08 16:43:54.487: D/PlayerManager(20733): Did Wi-Fi Changed: false
|
|
|
08-08 16:43:55.047: V/ConnectionChangeReceiver(20733): onReceive(Context context, Intent intent)
08-08 16:43:55.077: D/ConnectionChangeReceiver(20733): ssid changed from s_ssid="Walter_Meth_Lab" to newSsid="Kings_Landing"
这是我的 OnReceive()
public class ConnectionChangeReceiver extends BroadcastReceiver {
private static final String TAG = "ConnectionChangeReceiver";
private static String s_ssid = null;
private static String s_ipAddress = null;
private static String mNetworkType;
private static ConnectionChangeReceiver sInstance;
private ConnectionChangeListener mConnectionChangeListener;
private boolean mHasWifiChanged;
public static ConnectionChangeReceiver getInstance() {
Log.v(TAG, "getInstance()");
synchronized (ConnectionChangeReceiver.class) {
if (sInstance == null) {
sInstance = new ConnectionChangeReceiver();
}
}
return sInstance;
}
public boolean WifiChanged() {
return mHasWifiChanged;
}
public void setConnectionChangeListener(final ConnectionChangeListener listener) {
this.mConnectionChangeListener = listener;
}
@Override
public void onReceive(final Context context, final Intent intent) {
Log.v(TAG, "onReceive(Context context, Intent intent)");
mHasWifiChanged = false;
String newSsid = null;
String action = intent.getAction();
if ((action.equals(WifiManager.NETWORK_STATE_CHANGED_ACTION)) || (action.equals(WifiManager.WIFI_STATE_CHANGED_ACTION))
|| (action.equals("android.net.conn.CONNECTIVITY_CHANGE"))) {
NetworkInfo networkInfo = (NetworkInfo) intent.getParcelableExtra(ConnectivityManager.EXTRA_NETWORK_INFO);
if (networkInfo != null) {
if (networkInfo.getTypeName().equals("WIFI")) {
WifiManager wm = (WifiManager) context.getSystemService(Context.WIFI_SERVICE);
if (wm != null) {
WifiInfo connectionInfo = wm.getConnectionInfo();
if (connectionInfo != null) {
newSsid = connectionInfo.getSSID();
if ((newSsid != null) && (s_ssid != null) && (newSsid.compareTo(s_ssid) != 0)) {
Log.d(TAG, "ssid changed from s_ssid=" + s_ssid + " to newSsid=" + newSsid);
mHasWifiChanged = true;
}
}
}
}
}
}
s_ssid = newSsid;
这是我使用 boolean 值的另一个 Activity
boolean WifiChanged = ConnectionChangeReceiver.getInstance().WifiChanged();
Log.d(TAG, "Did Wi-Fi Changed:" + WifiChanged);
if (WifiChanged) {
//Do Something
}
如果 Wi-Fi ssid 发生变化,列表应该根据 WifiChanged true 进行更改,但它始终会针对 WifiChanged false 进行更改,因为 ChangeReceiver() 不会按时返回 true 并且使用默认的 false。
最佳答案
有很多方法可以做到这一点。
我更喜欢使用 LocalBroadcastManager
。
这将如何工作:不是让 Activity 请求信息,而是让 ConnectionChangeReceiver
交付它 - 当它可用时。 ConnectionChangeReceiver
处理完接收到的 intent
后,它会发送一个 local
广播。如果您的 Activity 是活跃的并且正在聆听,它就会对此使用react。
// Snippet from your `ConnectionChangeReceiver # onReceive(...)` method
if (connectionInfo != null) {
newSsid = connectionInfo.getSSID();
if ((newSsid != null) && (s_ssid != null) && (newSsid.compareTo(s_ssid) != 0)) {
Log.d(TAG, "ssid changed from s_ssid=" + s_ssid + " to newSsid=" + newSsid);
mHasWifiChanged = true;
// We can send a local broadcast now
// Note that the String `"com.my.app.wifi.WIFI_RELATED_CHANGE"` can be
// customized to your preference
Intent localIntent = new Intent("com.my.app.wifi.WIFI_RELATED_CHANGE");
// Including this extra is redundant here since `mHasWifiChanged` will
// always be true at this point. I am including it for example sake.
// Again, notice that the key `"com.my.app.wifi.WIFI_HAS_CHANGED"` can
// be customized
localIntent.putExtra("com.my.app.wifi.WIFI_HAS_CHANGED", mHasWifiChanged);
// Broadcasts the Intent to receivers in this app
LocalBroadcastManager.getInstance(context).sendBroadcast(localIntent);
}
}
在 Activity 方面:在您的 Activity 中创建一个 BroadcastReceiver
并将其设置为监听操作 "com.my.app.wifi.WIFI_RELATED_CHANGE"
。此字符串值必须与从 ConnectionChangeReceiver #onReceive(...)
发送广播时使用的值相同:
// Declared as a class member in your Activity
BroadcastReceiver wifiRelatedChangeListener = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
if (action.equals("com.my.app.wifi.WIFI_RELATED_CHANGE")) {
// In your current setup, `mHasWifiChanged` will always be true
// Act on it
}
}
};
您应该将 BroadcastReceiver
声明为类成员。这将允许您适本地注册和取消注册 BroadcastReceiver
:在 onResume()
中注册并在 onPause()
中取消注册。
在您的 Activity 的 onResume()
中,注册此接收器以监听操作 com.my.app.wifi.WIFI_RELATED_CHANGE
:
@Override
public void onResume() {
super.onResume();
// Activity has come to foreground. Register to listen for changes to wifi state.
// Create an IntentFilter with action `com.my.app.wifi.WIFI_RELATED_CHANGE`
IntentFilter intentFilter = new IntentFilter("com.my.app.wifi.WIFI_RELATED_CHANGE");
// Register your broadcastreceiver to receive broadcasts
// with action `com.my.app.wifi.WIFI_RELATED_CHANGE`
LocalBroadcastManager.getInstance(this)
.registerReceiver(wifiRelatedChangeListener, intentFilter);
}
在onPause()
中注销接收者:
@Override
public void onPause() {
super.onPause();
// Activity is going to background. No need to listen anymore
LocalBroadcastManager.getInstance(this).unregisterReceiver(wifiRelatedChangeListener);
}
请注意,您可以在许多 Activity 中声明一个接收器,例如 wifiRelatedChangeListener
。广播从 ConnectionChangeReceiver # onReceive(...)
发送一次。无论此时哪个 Activity 在前台/正在收听,都将收到此广播并据此采取行动。
By that time its too late
这个问题不会出现在上面讨论的解决方案中。
关于java - android广播接收器OnReceive()延迟导致错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25215280/
谁能给我提供代码或链接,以便在可能的情况下使用 UDP 发送和接收广播消息? 我一直被困在一个问题中,希望你们能帮助我解决它。谢谢 最佳答案 这是一个 C# 示例: using System; usi
我想将形状为 [a,b,c] 的张量中的元素相乘,每个元素在第 3 维中使用来自形状为 [a,b] 的张量的标量。 例如, x = |[1,2][3,4][5,6]| |[1,2][3,4][5,6]
广播是使具有不同形状的数组具有用于算术运算的兼容形状的过程。在 numpy 中,我们可以广播数组。 TensorFlow 图是否支持类似于 numpy 的广播? 最佳答案 是的,它是支持的。打开终端并
我有一个刷新功能,需要广播到子 Controller 。我在父 Controller 中做了类似的事情: // Refresh/Cancel $scope.OnGridBODRefre
我正在尝试在计算中使用字典值,如下所示: mydict = dict(zip(['key1', 'key2', 'key3'], [1, 2, 3])) print
刚刚掌握使用 MPI 的 Java 接口(interface)进行并行编程。只是想知道是否有人可以非常简单地解释广播的工作原理? 我有以下内容: if (me ==0) { // This is th
我正在处理一个项目,当我发送消息时,我将它作为通知发送给另一个用户使用广播它工作正常但是当我再次发送新消息然后替换为旧通知而不创建新通知 下面是我生成通知的代码 NotificationCompat.
我是 android 的初学者。但我非常需要你的帮助。我有一个流媒体视频广播视频项目。我找不到好的示例,在哪里可以实现从摄像机录制视频、将流发送(上传)到服务器以及从服务器下载(获取流)到播放器。请帮
请帮我解决我的问题。当我从父 Controller 调用并在子 Controller 中捕获时,为什么 $broadcast 函数不起作用?
我如何从 shell 中看到设置了哪些套接字选项?我特别想知道是否设置了 SO_BROADCAST? 最佳答案 你看过lsof了吗? 关于linux - 广播 socket ,我们在Stack Ove
当我在 Numpy 中进行此操作时会发生什么? a = np.ones([500,1]) b = np.ones([5000,])/2 c = a + b # a.shape (500,1) # b.
我有一个 Nexus S,当我在手机上手动更改日期时,并不总是广播 ACTION_DATE_CHANGED。如果我将日期从 2014 年 2 月 13 日更改为 2014 年 2 月 14 日,我还没
环境:springboot2.3.9RELEASE + RocketMQ4.8.0 依赖 <dependency>  
UDP 广播 面向连接的传输(如 TCP)管理两个网络端点之间的连接的建立,在连接的生命周期的有序和可靠的消息传输,以及最后,连接的有序终止。相比之下,类似 UDP 的无连接协议中则没有持久化连接的概
我正在开发一个带有 Angular 的单页应用程序,我需要在两个不同的指令之间进行通信,这些指令基本上没有父子关系。 在指令 A 中,我有 2 个地方需要从不同的功能广播相同的事件。在指令 B 中,为
我有一个带有多个重复项的主要二维 numpy 数组和一个具有第一个唯一值的辅助数组。 [[ 0 0 1 ] [ 1 0 2 ] [ 2 0 2 ] ... [ 0 0 1 ]
我正在制作多人网络游戏。现在要连接到服务器,客户端需要服务器的 ip 地址。 所以,我的实现方式如下。 客户端在广播 IP 和端口 A 上广播其 IP 地址。服务器通过 A 监听它,并且 服务器与客户
是否可以在没有 Urban Airship 等服务的情况下广播推送通知? 谢谢。 最佳答案 当然可以,但是您需要自己实现整个基础架构。 http://developer.apple.com/libra
我想复制矩阵的每一行 M没有任何复制发生(即通过创建 View ): 0 1 0 1 2 3 -> 0 1 2 3
我从一个 2D 数组开始,想将它广播到一个 3D 数组(例如,从灰度图像到 rgb 图像)。这是我使用的代码。 >>> img_grey = np.random.randn(4, 4) >>> img
我是一名优秀的程序员,十分优秀!