时间:2021-05-20
前言
最近因为工作的需要,要自定义展示Wifi信号强弱的需要,就通过利用系统广播的方式实现了一个自定义View——WifiStateView,下面话不多说了,感兴趣的朋友们一起来看看详细的介绍吧。
实现的效果图如下所示:
用不同的图片来表示Wifi信号的强弱,可以自定义Wifi信号等级
图标简陋了点,根据需要来替换即可
/** * 作者: 叶应是叶 * 时间: 2017/8/22 18:25 * 描述: */public class WifiStateView extends AppCompatImageView { private WifiManager wifiManager; private WifiHandler wifiHandler; //没有开启Wifi或开启了Wifi但没有连接 private static final int LEVEL_NONE = 0; //Wifi信号等级(最弱) private static final int LEVEL_1 = 1; //Wifi信号等级 private static final int LEVEL_2 = 2; //Wifi信号等级 private static final int LEVEL_3 = 3; //Wifi信号等级(最强) private static final int LEVEL_4 = 4; private final String TAG = "WifiStateView"; private static class WifiHandler extends Handler { //虚引用 private WeakReference<WifiStateView> stateViewWeakReference; WifiHandler(WifiStateView wifiStateView) { stateViewWeakReference = new WeakReference<>(wifiStateView); } @Override public void handleMessage(Message msg) { WifiStateView wifiStateView = stateViewWeakReference.get(); if (wifiStateView == null) { return; } switch (msg.what) { case LEVEL_1: wifiStateView.setImageResource(R.drawable.wifi_1); break; case LEVEL_2: wifiStateView.setImageResource(R.drawable.wifi_2); break; case LEVEL_3: wifiStateView.setImageResource(R.drawable.wifi_3); break; case LEVEL_4: wifiStateView.setImageResource(R.drawable.wifi_4); break; case LEVEL_NONE: default: wifiStateView.setImageResource(R.drawable.wifi_none); break; } } } private BroadcastReceiver wifiStateReceiver = new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { Log.e(TAG, "action " + intent.getAction()); switch (intent.getAction()) { case WifiManager.WIFI_STATE_CHANGED_ACTION: if (wifiManager.getWifiState() == WifiManager.WIFI_STATE_DISABLING) { wifiHandler.sendEmptyMessage(LEVEL_NONE); } break; case WifiManager.RSSI_CHANGED_ACTION: if (wifiManager.getWifiState() == WifiManager.WIFI_STATE_DISABLED) { wifiHandler.sendEmptyMessage(LEVEL_NONE); return; } WifiInfo wifiInfo = wifiManager.getConnectionInfo(); int level = WifiManager.calculateSignalLevel(wifiInfo.getRssi(), 5); Log.e(TAG, "level:" + level); wifiHandler.sendEmptyMessage(level); break; } } }; public WifiStateView(Context context) { this(context, null); } public WifiStateView(Context context, @Nullable AttributeSet attrs) { this(context, attrs, 0); } public WifiStateView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); wifiManager = (WifiManager) context.getApplicationContext().getSystemService(Context.WIFI_SERVICE); wifiHandler = new WifiHandler(this); } @Override protected void onAttachedToWindow() { super.onAttachedToWindow(); IntentFilter intentFilter = new IntentFilter(); //Wifi连接状态变化 intentFilter.addAction(WifiManager.WIFI_STATE_CHANGED_ACTION); //Wifi信号强度变化 intentFilter.addAction(WifiManager.RSSI_CHANGED_ACTION); getContext().registerReceiver(wifiStateReceiver, intentFilter); } @Override protected void onDetachedFromWindow() { super.onDetachedFromWindow(); wifiHandler.removeCallbacksAndMessages(null); getContext().unregisterReceiver(wifiStateReceiver); }}这里提供代码下载:
github地址:https://github.com/leavesC/WifiStateView
本地下载:http://xiazai.jb51.net/201708/yuanma/WifiStateView(jb51.net).rar
总结
以上就是这篇文章的全部内容了,希望本文的内容对各位Android开发者们的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了Android自定义View实现抖音飘动红心效果的具体代码,供大家参考,具体内容如下自定义View——抖音飘动红心效果展示动画效果使用自定义
Android自定义的view,主要是继承view,然后实现ondraw这个方法,来进行绘制。1.编写自己的自定义view2.加入逻辑线程3.提取和封装自定义v
Android自定义View实现抽屉效果说明这个自定义View,没有处理好多点触摸问题View跟着手指移动,没有采用传统的scrollBy方法,而是通过不停地重
Android自定义View的构造函数自定义View是Android中一个常见的需求,每个自定义的View都需要实现三个基本的构造函数,而这三个构造函数又有两种
Android自定义View时使用TypedArray配置样式属性详细介绍在自定义view时为了提高复用性和扩展性,可以为自定义的view添加样式属性的配置,比