編輯:關於Android編程
最近博主在學frangment框架,因此想著想著就想通過listfragment完成對wifi列表的獲取。
好!現在就不說廢話了。
一.wifi的基礎知識
在Android的官方文檔中定義了如下五種狀態:
WIFI_STATE_DISABLING WIFI網卡正在關閉 0
WIFI_STATE_DISABLED WIFI網卡不可用 1
而要想獲得wifi的信息,就需要一個wifimanager對象,而
wifimanager對象需要使用Context.getSystemService(Context.WIFI_SERVICE)來獲取WifiManager對象。
在這裡我們需要知道activity這類事繼承自Context的,因此可以MainActivity.this.getSystemService(Context.WIFI_SERVICE)來
獲取對象。如果要想得到周圍的WIFI熱點列表,可以使用WifiManager.getScanResults()返回一個ScanResult列表
以下是從別的博主那轉載的相關wifi基本知識
主要是通過wifi 硬件的掃描來獲取一些周邊的wifi 熱點的信息。 在我們進行wifi 搜索的時候,一般會搜到這些信息,首先是接入點名字、接入點信息的強弱、還有接入點使用的安全模式,是WPA、WPE;打開這個類,我們可以看到以下幾個信息 BSSID 接入點的地址,這裡主要是指小范圍幾個無線設備相連接所獲取的地址,比如說兩台筆記本通過無線網卡進行連接,雙方的無線網卡分配的地址。
SSID 網絡的名字,當我們搜索一個網絡時,就是靠這個來區分每個不同的網絡接入點。
Capabilities 網絡接入的性能,這裡主要是來判斷網絡的加密方式等。
Frequency 頻率,每一個頻道交互的MHz 數。
Level 等級,主要來判斷網絡連接的優先數。
這裡只提供了一個方法,就是將獲得信息編程字符串toString()。
在我們連通一個wifi 接入點的時候,需要獲取到的一些信息。大家可以跟我們有線的設備進行對比一下。
這裡的數據相對來說比較復雜一下。
六個子類
WifiConfiguration.AuthAlgorthm 用來判斷加密方法。
WifiConfiguration.GroupCipher 獲取使用GroupCipher 的方法來進行加密。
WifiConfiguration.KeyMgmt 獲取使用KeyMgmt 進行。
WifiConfiguration.PairwiseCipher 獲取使用WPA 方式的加密。
WifiConfiguration.Protocol 獲取使用哪一種協議進行加密。
wifiConfiguration.Status 獲取當前網絡的狀態。
對於上述加密感興趣的朋友,可以在網上搜索相關的內容。
設置WifiConfiguration的屬性:
WifiConfiguration.AuthAlgorthm 設置加密方法。
可選參數:LEAP只用於leap,
OPEN 被wpa/wpa2需要,
SHARED需要一個靜態的wep key
WifiConfiguration.GroupCipher 使用GroupCipher 的方法來進行加密。
可選參數:CCMP,TKIP,WEP104,WEP40
WifiConfiguration.KeyMgmt 鍵管理機制(keymanagerment),使用KeyMgmt 進行。
可選參數IEEE8021X,NONE,WPA_EAP,WPA_PSK
WifiConfiguration.PairwiseCipher 設置加密方式。
可選參數 CCMP,NONE,TKIP
WifiConfiguration.Protocol 設置一種協議進行加密。
可選參數 RSN,WPA,
wifiConfiguration.Status 設置當前網絡的狀態。
可選參數CURRENT,DISABLED,ENABLED
在我們的wifi 已經連通了以後,可以通過這個類獲得一些已經連通的wifi 連接的信息獲取當前鏈接的信息,
這裡信息就比較簡單了,這裡簡單介紹一下這裡的方法:
getBSSID() 獲取BSSID
getDetailedStateOf() 獲取客戶端的連通性
getHiddenSSID() 獲得SSID 是否被隱藏
getIpAddress() 獲取IP 地址
getLinkSpeed() 獲得連接的速度
getMacAddress() 獲得Mac 地址
getRssi() 獲得802.11n 網絡的信號
getSSID() 獲得SSID
getSupplicanState() 返回具體客戶端狀態的信息
這個不用說,就是用來管理我們的wifi 連接,這裡已經定義好了一些類,可以供我們使用。
這裡來說相對復雜,裡面的內容比較多,但是通過字面意思,我們還是可以獲得很多相關的信息。這個類裡面預先定義了許多常量,我們可以直接使用,不用再次創建。
這裡還是簡單介紹一下這裡的方法:
addNetwork(WifiConfiguration config) 通過獲取到的網絡的鏈接狀態信息,來添加網絡
calculateSignalLevel(int rssi , int numLevels) 計算信號的等級
compareSignalLevel(int rssiA, int rssiB) 對比連接A 和連接B
createWifiLock(int lockType, String tag) 創建一個wifi 鎖,鎖定當前的wifi 連接
disableNetwork(int netId) 讓一個網絡連接失效
disconnect() 斷開連接
enableNetwork(int netId, Boolean disableOthers) 連接一個連接
getConfiguredNetworks() 獲取網絡連接的狀態
getConnectionInfo() 獲取當前連接的信息
getDhcpInfo() 獲取DHCP 的信息
getScanResulats() 獲取掃描測試的結果
getWifiState() 獲取一個wifi 接入點是否有效
isWifiEnabled() 判斷一個wifi 連接是否有效
pingSupplicant() ping 一個連接,判斷是否能連通
ressociate() 即便連接沒有准備好,也要連通
reconnect() 如果連接准備好了,連通
removeNetwork() 移除某一個網絡
saveConfiguration() 保留一個配置信息
setWifiEnabled() 讓一個連接有效
startScan() 開始掃描
updateNetwork(WifiConfiguration config) 更新一個網絡連接的信息
此外wifiManaer 還提供了一個內部的子類,也就是wifiManagerLock,WifiManagerLock 的作用是這樣的,
在普通的狀態下,如果我們的wifi 的狀態處於閒置,那麼網絡的連通,將會暫時中斷。
但是如果我們把當前的網絡狀態鎖上,那麼wifi 連通將會保持在一定狀態,當然接觸鎖定之後,就會恢復常態
mainfest的代碼圖
mainactivity
package com.example.wifilisttest; import java.util.List; import android.app.Activity; import android.content.Context; import android.net.wifi.ScanResult; import android.net.wifi.WifiManager; import android.os.Bundle; import android.support.v4.app.FragmentActivity; import android.support.v4.app.FragmentManager; import android.view.Menu; import android.view.MenuItem; import android.widget.Button; import android.widget.Toast; public class MainActivity extends FragmentActivity { private WifiManager wifiManager; Listlist; String[] Flist=null; Button but; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Fragment1 f1 = new Fragment1(); FragmentManager manager = getSupportFragmentManager(); manager.beginTransaction().add(R.id.fragments, f1).commit(); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { // Handle action bar item clicks here. The action bar will // automatically handle clicks on the Home/Up button, so long // as you specify a parent activity in AndroidManifest.xml. int id = item.getItemId(); if (id == R.id.action_settings) { return true; } return super.onOptionsItemSelected(item); } }
package com.example.wifilisttest; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import android.app.Activity; import android.content.Context; import android.net.wifi.ScanResult; import android.net.wifi.WifiManager; import android.os.Bundle; import android.support.v4.app.ListFragment; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.ListView; import android.widget.SimpleAdapter; import android.widget.TextView; import android.widget.Toast; /** * @描述 在Fragment中要使用ListView,就要用ListFragment * */ public class Fragment1 extends ListFragment { private String TAG = Fragment1.class.getName(); private ListView list ; private SimpleAdapter adapter; Listllll=null; String[] Flist; private TextView Tv; private WifiManager wifiManager; List listb; /** * @描述 在onCreateView中加載布局 * */ @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment1, container,false); list = (ListView) view.findViewById(android.R.id.list); Tv=(TextView)view.findViewById(R.id.tv); Tv.setText("nullTitle"); Log.i(TAG, "--------onCreateView"); return view; } @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Bundle b = savedInstanceState; Log.i(TAG, "--------onCreate"); wifiManager = (WifiManager) getActivity().getSystemService(Context.WIFI_SERVICE); listb = wifiManager.getScanResults(); //數組初始化要注意 String[] listk=new String[listb.size()]; if(listb!=null){ for( int i=0;i view= (HashMap ) l.getItemAtPosition(position); System.out.println(view.get("title").toString()+"+++++++++title"); Toast.makeText(getActivity(), TAG+l.getItemIdAtPosition(position), Toast.LENGTH_LONG).show(); System.out.println(v); System.out.println(position); } private List> getData(String[] strs) { List
fragment1.xml<framelayout android:id="@+id/fragments" android:layout_height="wrap_content" android:layout_width="wrap_content"></framelayout>
這篇文章主要介紹一下如何實現View的3D旋轉效果,實現的主要原理就是圍繞Y軸旋轉,同時在Z軸方面上有一個深入的縮放。演示的demo主要有以下幾個重點: 1,自定義旋轉動
支付寶上有一個咻一咻的功能,就是點擊圖片後四周有水波紋的這種效果,今天也寫一個類似的功能。效果如下所示:思路:就是幾個圓的半徑不斷在變大,這個可以使用動畫縮放實現,還有透
前言由於大部分android初級教程都沒教怎麼選擇時間,初學者碰到這種難免會有些不知所措,難道要讓用戶自己輸入日期時間?先不說用戶體驗不好,處理用戶輸入各式各樣的日期格式
Github項目地址,歡迎star~!初始化OpenGL ES環境OpenGL ES的使用,一般包括如下幾個步驟:1. EGL Context初始化2. OpenGL E