android wifi channel,Android实践 -- Android Wi-Fi 直连
Android Wi-Fi 直連
Wi-Fi直連是Android 4.0(API level 14)或更高的版本的才加入的新功能,使用Wi-Fi直連相關的
API可以發現并連接支持Wi-Fi直連的設備,連接之后設備之間可以通信,傳輸的距離比藍牙的傳輸距離
要遠很多
API 概述
Wi-Fi直連的方法
類WifiP2pManager提供了一些方法來使用Wi-Fi直連的相關的接口來發現連接設備
方法
描述
initialize()
在Wi-Fi框架中注冊,必須在其他方法之前調用
connect()
和另外的直連設備連接
cancelConnect()
取消正在連接的動作
requestConnectInfo()
請求已經連接的信息
createGroup()
創建直連的設備組
removeGroup()
刪除當前的設置組
requestGroupInfo()
請求當前組的信息
discoverPeers()
初始化搜索
requestPeers()
請求已經發現的設備的列表
Wi-Fi直連的監聽
類WifiP2pManager中也提供了很多的監聽接口,計時的通知當前的 activity相關的搜索和連接的
結果
接口
相關的操作
WifiP2pManager.ActionListener
相關的操作:connect(), cancelConnect(), createGroup(), removeGroup(), and discoverPeers()
WifiP2pManager.ChannelListener
相關的操作:initialize()
WifiP2pManager.ConnectionInfoListener
相關的操作:requestConnectInfo()
WifiP2pManager.GroupInfoListener
相關的操作:requestGroupInfo()
WifiP2pManager.PeerListListener
相關的操作:requestPeers()
Wi-Fi直連的Intent
Intent
描述
WIFI_P2P_CONNECTION_CHANGED_ACTION
當設備的Wi-Fi的連接狀態發生變化時觸發
WIFI_P2P_PEERS_CHANGED_ACTION
在調用discoverPeers()時觸發,可以調用requestPeers()方法更新設備列表
WIFI_P2P_STATE_CHANGED_ACTION
Wi-Fi直連的狀態發生變化時觸發
WIFI_P2P_THIS_DEVICE_CHANGED_ACTION
Wi-Fi直連的設備的詳細信息發生變化時觸發
創建Wi-Fi直連的應用
初始化設置
首先要保證設置支持Wi-Fi直連相關的協議,如果支持,我們就可以獲得WifiP2pManager的實例,創建并注冊相關的廣播,使用相關的
api
在AndroidManifest中必須聲明相關的權限,Wi-Fi直連是在api level 14及更高的版本才能使用,還要聲明android:minSdkVersion="14"
初始化WifiP2pManager的實例,并注冊相關的廣播,監聽Wi-Fi直連的狀態
private WifiP2pManager mManager;
private Channel mChannel;
private IntentFilter directFilter;
private WiFiDirectReceiver directReceiver ;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mManager = (WifiP2pManager)this.getSystemService(Context.WIFI_P2P_SERVICE);
mChannel = mManager.initialize(this, this.getMainLooper(), null);
directReceiver = new WiFiDirectReceiver(mManager, mChannel, this);
directFilter = new IntentFilter();
directFilter.addAction(WifiP2pManager.WIFI_P2P_STATE_CHANGED_ACTION);
directFilter.addAction(WifiP2pManager.WIFI_P2P_PEERS_CHANGED_ACTION);
directFilter.addAction(WifiP2pManager.WIFI_P2P_CONNECTION_CHANGED_ACTION);
directFilter.addAction(WifiP2pManager.WIFI_P2P_THIS_DEVICE_CHANGED_ACTION);
}
//注冊廣播監聽
@Override
protected void onResume() {
super.onResume();
this.registerReceiver(directReceiver, directFilter);
}
//取消注冊
@Override
protected void onPause() {
super.onPause();
this.unregisterReceiver(directReceiver);
}
廣播接受
public class WiFiDirectReceiver extends BroadcastReceiver{
private WifiP2pManager mManager;
private Channel mChannel;
private MainActivity mActivity;
private PeerListListener mListener;
private WifiP2pConfig mConfig = new WifiP2pConfig();
public WiFiDirectReceiver(){}
public WiFiDirectReceiver(WifiP2pManager manager,Channel channel,MainActivity activity){
this.mManager = manager;
this.mChannel = channel;
this.mActivity = activity;
}
@Override
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
Log.e("tag", "===============wifi direct action: "+action);
if(action.equals(WifiP2pManager.WIFI_P2P_STATE_CHANGED_ACTION)){
int state = intent.getIntExtra(WifiP2pManager.EXTRA_WIFI_STATE, -1);
if(state == WifiP2pManager.WIFI_P2P_STATE_ENABLED){
//打開
}else if(state == WifiP2pManager.WIFI_P2P_STATE_DISABLED){
//關閉
}
}else if(action.equals(WifiP2pManager.WIFI_P2P_PEERS_CHANGED_ACTION)){
}else if(action.equals(WifiP2pManager.WIFI_P2P_CONNECTION_CHANGED_ACTION)){
}else if(action.equals(WifiP2pManager.WIFI_P2P_THIS_DEVICE_CHANGED_ACTION)){
}
}
}
發現設備
在調用之后initialize()方法之后,會觸發WifiP2pManager.WIFI_P2P_STATE_CHANGED_ACTION的廣播,在BroadcastReceiver
中,如果WifiP2pManager.WIFI_P2P_STATE_ENABLED的狀態已經打開,在BroadcastReceiver調用discoverPeers方法,如果發現設備
會回調onSuccess方法
mManager.discoverPeers(mChannel, new WifiP2pManager.ActionListener() {
@Override
public void onSuccess() {
Log.e("tag", "===================discovery success");
}
@Override
public void onFailure(int reason) {
Log.e("tag", "===================discovery failed");
}
});
如果發現設備,系統會觸發WifiP2pManager.WIFI_P2P_PEERS_CHANGED_ACTION這個廣播,在這個廣播中可以調用requestPeers方法可以列出所有的
設備
if(null != mManager){
mManager.requestPeers(mChannel, new WifiP2pManager.PeerListListener() {
@Override
public void onPeersAvailable(WifiP2pDeviceList peers) {
Log.e("tag", "==================peers list size: "+peers.getDeviceList().size());
for(WifiP2pDevice device: peers.getDeviceList()){
Log.e("tag", "==================device addr: "+device.deviceName+" name: "+device.deviceName);
}
}
});
}
連接設備
對于已經發現的設備我們可以調用connect()方法連接,需要初始化WifiP2pConfig,并設置config的deviceAddress
private WifiP2pConfig mConfig = new WifiP2pConfig();
mConfig.deviceAddress = device.deviceAddress;
mManager.connect(mChannel, mConfig, new WifiP2pManager.ActionListener() {
@Override
public void onSuccess() {
Log.e("tag", "==============connnect success");
}
@Override
public void onFailure(int reason) {
Log.e("tag", "=================connect failed");
}
});
連接成功會回調onSuccess方法
傳輸數據待續。。。
總結
以上是生活随笔為你收集整理的android wifi channel,Android实践 -- Android Wi-Fi 直连的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 鸿蒙系统魔改,华为EMUI 11正式发布
- 下一篇: matlab 正轴测图,正等轴测图的画法