Android 判断用户2G/3G/4G移动数据网络

在做 Android App 的时候,为了给用户省流量,为了不激起用户的愤怒,为了更好的用户体验,是需要根据用户当前网络情况来做一些调整的,也可以在 App 的设置模块里,让用户自己选择,在 2G / 3G / 4G 网络条件下,是否允许请求一些流量比较大的数据。

通过 Android 提供的 TelephonyManager 和 ConnectivityManager 都可以获取到 NetworksInfo 对象,可以通过 getType() 获取类型,判断是 wifi 还是 mobile ,如果是 mobile ,可以通过 NetworksInfo 对象的 getSubType() 和 getSubTypeName() 可以获取到对于的网络类型和名字。

网络类型和名字定义在 TelephonyManager 类里。

/** Network type is unknown */
public static final int NETWORK_TYPE_UNKNOWN = 0;
/** Current network is GPRS */
public static final int NETWORK_TYPE_GPRS = 1;
/** Current network is EDGE */
public static final int NETWORK_TYPE_EDGE = 2;
/** Current network is UMTS */
public static final int NETWORK_TYPE_UMTS = 3;
/** Current network is CDMA: Either IS95A or IS95B*/
public static final int NETWORK_TYPE_CDMA = 4;
/** Current network is EVDO revision 0*/
public static final int NETWORK_TYPE_EVDO_0 = 5;
/** Current network is EVDO revision A*/
public static final int NETWORK_TYPE_EVDO_A = 6;
/** Current network is 1xRTT*/
public static final int NETWORK_TYPE_1xRTT = 7;
/** Current network is HSDPA */
public static final int NETWORK_TYPE_HSDPA = 8;
/** Current network is HSUPA */
public static final int NETWORK_TYPE_HSUPA = 9;
/** Current network is HSPA */
public static final int NETWORK_TYPE_HSPA = 10;
/** Current network is iDen */
public static final int NETWORK_TYPE_IDEN = 11;
/** Current network is EVDO revision B*/
public static final int NETWORK_TYPE_EVDO_B = 12;
/** Current network is LTE */
public static final int NETWORK_TYPE_LTE = 13;
/** Current network is eHRPD */
public static final int NETWORK_TYPE_EHRPD = 14;
/** Current network is HSPA+ */
public static final int NETWORK_TYPE_HSPAP = 15;

看到这个代码和注释,相信没有这方面知识的人很难看懂,都啥玩意?这注释跟没注释有啥区别?!就是让人看着更加闹心而已。所以说,注释对阅读代码的人很重要。当然这些东西可能太专业了,写这些代码的人估计是想写也不知道该怎么了,得写多大一坨啊?!我在最后会贴上一些我整理的资料,可以供大家参考一下,不是很详细,也不专业,就是大概有个印象。

TelephonyManager 还提供了 getNetworkTypeName(int type) 的方法,这个方法可以返回一个字符串,但是信息量不大。

那怎么判断是 2G , 3G 还是 4G 网络呢?TelephonyManager 还提供了另外一个方法,getNetworkClass(int networkType) ,但这个方法被隐藏掉了,我把代码贴一下。

public static int getNetworkClass(int networkType) {
switch (networkType) {
case NETWORK_TYPE_GPRS:
case NETWORK_TYPE_EDGE:
case NETWORK_TYPE_CDMA:
case NETWORK_TYPE_1xRTT:
case NETWORK_TYPE_IDEN:
return NETWORK_CLASS_2_G;
case NETWORK_TYPE_UMTS:
case NETWORK_TYPE_EVDO_0:
case NETWORK_TYPE_EVDO_A:
case NETWORK_TYPE_HSDPA:
case NETWORK_TYPE_HSUPA:
case NETWORK_TYPE_HSPA:
case NETWORK_TYPE_EVDO_B:
case NETWORK_TYPE_EHRPD:
case NETWORK_TYPE_HSPAP:
return NETWORK_CLASS_3_G;
case NETWORK_TYPE_LTE:
return NETWORK_CLASS_4_G;
default:
return NETWORK_CLASS_UNKNOWN;
}
}

然后下面是这几个常量的值。

/** Unknown network class. {@hide} */
public static final int NETWORK_CLASS_UNKNOWN = 0;
/** Class of broadly defined "2G" networks. {@hide} */
public static final int NETWORK_CLASS_2_G = 1;
/** Class of broadly defined "3G" networks. {@hide} */
public static final int NETWORK_CLASS_3_G = 2;
/** Class of broadly defined "4G" networks. {@hide} */
public static final int NETWORK_CLASS_4_G = 3;

不知道为啥要把这些东西给隐藏起来,然道是不靠谱?!还是其他的更好的方式?!不知道,先这样吧,现在通过上面的手段,是可以知道用户用的是什么网络,当然也可以区分出来用户使用的是 2G , 3G 还是 4G 了。当然,你获取到这些数据后,你也可以推算出用户用的是哪家公司的网络,移动的,联通的,还是电信的,当然,只在中国。而且虚拟运营商开始真正上市后,这个就区分不出来是京东的,还是国美,苏宁的了,但是你可以知道你的手机号用的是联通的网还是移动的网。

最后贴上我收集整理的一些资料,可以参考一下。

GPRS 2G(2.5) General Packet Radia Service 114kbps
EDGE 2G(2.75G) Enhanced Data Rate for GSM Evolution 384kbps
UMTS 3G WCDMA 联通3G Universal Mobile Telecommunication System 完整的3G移动通信技术标准
CDMA 2G 电信 Code Division Multiple Access 码分多址
EVDO_0 3G (EVDO 全程 CDMA2000 1xEV-DO) Evolution - Data Only (Data Optimized) 153.6kps - 2.4mbps 属于3G
EVDO_A 3G 1.8mbps - 3.1mbps 属于3G过渡,3.5G
1xRTT 2G CDMA2000 1xRTT (RTT - 无线电传输技术) 144kbps 2G的过渡,
HSDPA 3.5G 高速下行分组接入 3.5G WCDMA High Speed Downlink Packet Access 14.4mbps
HSUPA 3.5G High Speed Uplink Packet Access 高速上行链路分组接入 1.4 - 5.8 mbps
HSPA 3G (分HSDPA,HSUPA) High Speed Packet Access
IDEN 2G Integrated Dispatch Enhanced Networks 集成数字增强型网络 (属于2G,来自维基百科)
EVDO_B 3G EV-DO Rev.B 14.7Mbps 下行 3.5G
LTE 4G Long Term Evolution FDD-LTE 和 TDD-LTE , 3G过渡,升级版 LTE Advanced 才是4G
EHRPD 3G CDMA2000向LTE 4G的中间产物 Evolved High Rate Packet Data HRPD的升级
HSPAP 3G HSPAP 比 HSDPA 快些

转自:http://www.binkery.com/post/368.html

实例:

[java]view plaincopy

  1. importjava.io.BufferedReader;

  2. importjava.io.InputStreamReader;

  3. importjava.text.DecimalFormat;

  4. importjava.util.List;

  5. importandroid.content.Context;

  6. importandroid.net.ConnectivityManager;

  7. importandroid.net.NetworkInfo;

  8. importandroid.net.wifi.WifiInfo;

  9. importandroid.net.wifi.WifiManager;

  10. importandroid.telephony.NeighboringCellInfo;

  11. importandroid.telephony.TelephonyManager;

  12. importandroid.telephony.cdma.CdmaCellLocation;

  13. importandroid.telephony.gsm.GsmCellLocation;

  14. importandroid.util.Log;

  15. publicclassNetWorkUtil{

  16. publicstaticbooleanisWifiAvailable(){

  17. ConnectivityManagerconnectivityManager=(ConnectivityManager)ConfigManager

  18. .getContext().getSystemService(Context.CONNECTIVITY_SERVICE);

  19. NetworkInfonetworkInfo=connectivityManager.getActiveNetworkInfo();

  20. return(networkInfo!=null&&networkInfo.isConnected()&&networkInfo

  21. .getType()==ConnectivityManager.TYPE_WIFI);

  22. }

  23. /**

  24. *获取MAC地址

  25. *

  26. *@paramcontext

  27. *@return

  28. */

  29. publicstaticStringgetMacAddress(Contextcontext){

  30. if(context==null){

  31. return"";

  32. }

  33. StringlocalMac=null;

  34. if(isWifiAvailable()){

  35. localMac=getWifiMacAddress(context);

  36. }

  37. if(localMac!=null&&localMac.length()>0){

  38. localMac=localMac.replace(":","-").toLowerCase();

  39. returnlocalMac;

  40. }

  41. localMac=getMacFromCallCmd();

  42. if(localMac!=null){

  43. localMac=localMac.replace(":","-").toLowerCase();

  44. }

  45. returnlocalMac;

  46. }

  47. privatestaticStringgetWifiMacAddress(Contextcontext){

  48. StringlocalMac=null;

  49. try{

  50. WifiManagerwifi=(WifiManager)context

  51. .getSystemService(Context.WIFI_SERVICE);

  52. WifiInfoinfo=wifi.getConnectionInfo();

  53. if(wifi.isWifiEnabled()){

  54. localMac=info.getMacAddress();

  55. if(localMac!=null){

  56. localMac=localMac.replace(":","-").toLowerCase();

  57. returnlocalMac;

  58. }

  59. }

  60. }catch(Exceptione){

  61. e.printStackTrace();

  62. }

  63. returnnull;

  64. }

  65. /**

  66. *通过callCmd("busyboxifconfig","HWaddr")获取mac地址

  67. *

  68. *@attention需要设备装有busybox工具

  69. *@returnMacAddress

  70. */

  71. privatestaticStringgetMacFromCallCmd(){

  72. Stringresult="";

  73. result=callCmd("busyboxifconfig","HWaddr");

  74. if(result==null||result.length()<=0){

  75. returnnull;

  76. }

  77. DebugLog.v("tag","cmdresult:"+result);

  78. //对该行数据进行解析

  79. //例如:eth0Linkencap:EthernetHWaddr00:16:E8:3E:DF:67

  80. if(result.length()>0&&result.contains("HWaddr")==true){

  81. StringMac=result.substring(result.indexOf("HWaddr")+6,

  82. result.length()-1);

  83. if(Mac.length()>1){

  84. result=Mac.replaceAll("","");

  85. }

  86. }

  87. returnresult;

  88. }

  89. publicstaticStringcallCmd(Stringcmd,Stringfilter){

  90. Stringresult="";

  91. Stringline="";

  92. try{

  93. Processproc=Runtime.getRuntime().exec(cmd);

  94. InputStreamReaderis=newInputStreamReader(proc.getInputStream());

  95. BufferedReaderbr=newBufferedReader(is);

  96. //执行命令cmd,只取结果中含有filter的这一行

  97. while((line=br.readLine())!=null

  98. &&line.contains(filter)==false){

  99. }

  100. result=line;

  101. }catch(Exceptione){

  102. e.printStackTrace();

  103. }

  104. returnresult;

  105. }

  106. /**

  107. *网络是否可用

  108. *

  109. *@paramcontext

  110. *@return

  111. */

  112. publicstaticbooleanIsNetWorkEnable(Contextcontext){

  113. try{

  114. ConnectivityManagerconnectivity=(ConnectivityManager)context

  115. .getSystemService(Context.CONNECTIVITY_SERVICE);

  116. if(connectivity==null){

  117. ToastUtil.showMessage(context,"无法连接网络");

  118. returnfalse;

  119. }

  120. NetworkInfoinfo=connectivity.getActiveNetworkInfo();

  121. if(info!=null&&info.isConnected()){

  122. //判断当前网络是否已经连接

  123. if(info.getState()==NetworkInfo.State.CONNECTED){

  124. returntrue;

  125. }

  126. }

  127. }catch(Exceptione){

  128. e.printStackTrace();

  129. }

  130. ToastUtil.showMessage(context,"无法连接网络");

  131. returnfalse;

  132. }

  133. privatestaticfinalintNETWORK_TYPE_UNAVAILABLE=-1;

  134. //privatestaticfinalintNETWORK_TYPE_MOBILE=-100;

  135. privatestaticfinalintNETWORK_TYPE_WIFI=-101;

  136. privatestaticfinalintNETWORK_CLASS_WIFI=-101;

  137. privatestaticfinalintNETWORK_CLASS_UNAVAILABLE=-1;

  138. /**Unknownnetworkclass.*/

  139. privatestaticfinalintNETWORK_CLASS_UNKNOWN=0;

  140. /**Classofbroadlydefined"2G"networks.*/

  141. privatestaticfinalintNETWORK_CLASS_2_G=1;

  142. /**Classofbroadlydefined"3G"networks.*/

  143. privatestaticfinalintNETWORK_CLASS_3_G=2;

  144. /**Classofbroadlydefined"4G"networks.*/

  145. privatestaticfinalintNETWORK_CLASS_4_G=3;

  146. privatestaticDecimalFormatdf=newDecimalFormat("#.##");

  147. //适配低版本手机

  148. /**Networktypeisunknown*/

  149. publicstaticfinalintNETWORK_TYPE_UNKNOWN=0;

  150. /**CurrentnetworkisGPRS*/

  151. publicstaticfinalintNETWORK_TYPE_GPRS=1;

  152. /**CurrentnetworkisEDGE*/

  153. publicstaticfinalintNETWORK_TYPE_EDGE=2;

  154. /**CurrentnetworkisUMTS*/

  155. publicstaticfinalintNETWORK_TYPE_UMTS=3;

  156. /**CurrentnetworkisCDMA:EitherIS95AorIS95B*/

  157. publicstaticfinalintNETWORK_TYPE_CDMA=4;

  158. /**CurrentnetworkisEVDOrevision0*/

  159. publicstaticfinalintNETWORK_TYPE_EVDO_0=5;

  160. /**CurrentnetworkisEVDOrevisionA*/

  161. publicstaticfinalintNETWORK_TYPE_EVDO_A=6;

  162. /**Currentnetworkis1xRTT*/

  163. publicstaticfinalintNETWORK_TYPE_1xRTT=7;

  164. /**CurrentnetworkisHSDPA*/

  165. publicstaticfinalintNETWORK_TYPE_HSDPA=8;

  166. /**CurrentnetworkisHSUPA*/

  167. publicstaticfinalintNETWORK_TYPE_HSUPA=9;

  168. /**CurrentnetworkisHSPA*/

  169. publicstaticfinalintNETWORK_TYPE_HSPA=10;

  170. /**CurrentnetworkisiDen*/

  171. publicstaticfinalintNETWORK_TYPE_IDEN=11;

  172. /**CurrentnetworkisEVDOrevisionB*/

  173. publicstaticfinalintNETWORK_TYPE_EVDO_B=12;

  174. /**CurrentnetworkisLTE*/

  175. publicstaticfinalintNETWORK_TYPE_LTE=13;

  176. /**CurrentnetworkiseHRPD*/

  177. publicstaticfinalintNETWORK_TYPE_EHRPD=14;

  178. /**CurrentnetworkisHSPA+*/

  179. publicstaticfinalintNETWORK_TYPE_HSPAP=15;

  180. /**

  181. *格式化大小

  182. *

  183. *@paramsize

  184. *@return

  185. */

  186. publicstaticStringformatSize(longsize){

  187. Stringunit="B";

  188. floatlen=size;

  189. if(len>900){

  190. len/=1024f;

  191. unit="KB";

  192. }

  193. if(len>900){

  194. len/=1024f;

  195. unit="MB";

  196. }

  197. if(len>900){

  198. len/=1024f;

  199. unit="GB";

  200. }

  201. if(len>900){

  202. len/=1024f;

  203. unit="TB";

  204. }

  205. returndf.format(len)+unit;

  206. }

  207. publicstaticStringformatSizeBySecond(longsize){

  208. Stringunit="B";

  209. floatlen=size;

  210. if(len>900){

  211. len/=1024f;

  212. unit="KB";

  213. }

  214. if(len>900){

  215. len/=1024f;

  216. unit="MB";

  217. }

  218. if(len>900){

  219. len/=1024f;

  220. unit="GB";

  221. }

  222. if(len>900){

  223. len/=1024f;

  224. unit="TB";

  225. }

  226. returndf.format(len)+unit+"/s";

  227. }

  228. publicstaticStringformat(longsize){

  229. Stringunit="B";

  230. floatlen=size;

  231. if(len>1000){

  232. len/=1024f;

  233. unit="KB";

  234. if(len>1000){

  235. len/=1024f;

  236. unit="MB";

  237. if(len>1000){

  238. len/=1024f;

  239. unit="GB";

  240. }

  241. }

  242. }

  243. returndf.format(len)+"\n"+unit+"/s";

  244. }

  245. /**

  246. *获取运营商

  247. *

  248. *@return

  249. */

  250. publicstaticStringgetProvider(){

  251. Stringprovider="未知";

  252. try{

  253. TelephonyManagertelephonyManager=(TelephonyManager)ConfigManager

  254. .getContext().getSystemService(Context.TELEPHONY_SERVICE);

  255. StringIMSI=telephonyManager.getSubscriberId();

  256. Log.v("tag","getProvider.IMSI:"+IMSI);

  257. if(IMSI==null){

  258. if(TelephonyManager.SIM_STATE_READY==telephonyManager

  259. .getSimState()){

  260. Stringoperator=telephonyManager.getSimOperator();

  261. Log.v("tag","getProvider.operator:"+operator);

  262. if(operator!=null){

  263. if(operator.equals("46000")

  264. ||operator.equals("46002")

  265. ||operator.equals("46007")){

  266. provider="中国移动";

  267. }elseif(operator.equals("46001")){

  268. provider="中国联通";

  269. }elseif(operator.equals("46003")){

  270. provider="中国电信";

  271. }

  272. }

  273. }

  274. }else{

  275. if(IMSI.startsWith("46000")||IMSI.startsWith("46002")

  276. ||IMSI.startsWith("46007")){

  277. provider="中国移动";

  278. }elseif(IMSI.startsWith("46001")){

  279. provider="中国联通";

  280. }elseif(IMSI.startsWith("46003")){

  281. provider="中国电信";

  282. }

  283. }

  284. }catch(Exceptione){

  285. e.printStackTrace();

  286. }

  287. returnprovider;

  288. }

  289. /**

  290. *获取网络类型

  291. *

  292. *@return

  293. */

  294. publicstaticStringgetCurrentNetworkType(){

  295. intnetworkClass=getNetworkClass();

  296. Stringtype="未知";

  297. switch(networkClass){

  298. caseNETWORK_CLASS_UNAVAILABLE:

  299. type="无";

  300. break;

  301. caseNETWORK_CLASS_WIFI:

  302. type="Wi-Fi";

  303. break;

  304. caseNETWORK_CLASS_2_G:

  305. type="2G";

  306. break;

  307. caseNETWORK_CLASS_3_G:

  308. type="3G";

  309. break;

  310. caseNETWORK_CLASS_4_G:

  311. type="4G";

  312. break;

  313. caseNETWORK_CLASS_UNKNOWN:

  314. type="未知";

  315. break;

  316. }

  317. returntype;

  318. }

  319. privatestaticintgetNetworkClassByType(intnetworkType){

  320. switch(networkType){

  321. caseNETWORK_TYPE_UNAVAILABLE:

  322. returnNETWORK_CLASS_UNAVAILABLE;

  323. caseNETWORK_TYPE_WIFI:

  324. returnNETWORK_CLASS_WIFI;

  325. caseNETWORK_TYPE_GPRS:

  326. caseNETWORK_TYPE_EDGE:

  327. caseNETWORK_TYPE_CDMA:

  328. caseNETWORK_TYPE_1xRTT:

  329. caseNETWORK_TYPE_IDEN:

  330. returnNETWORK_CLASS_2_G;

  331. caseNETWORK_TYPE_UMTS:

  332. caseNETWORK_TYPE_EVDO_0:

  333. caseNETWORK_TYPE_EVDO_A:

  334. caseNETWORK_TYPE_HSDPA:

  335. caseNETWORK_TYPE_HSUPA:

  336. caseNETWORK_TYPE_HSPA:

  337. caseNETWORK_TYPE_EVDO_B:

  338. caseNETWORK_TYPE_EHRPD:

  339. caseNETWORK_TYPE_HSPAP:

  340. returnNETWORK_CLASS_3_G;

  341. caseNETWORK_TYPE_LTE:

  342. returnNETWORK_CLASS_4_G;

  343. default:

  344. returnNETWORK_CLASS_UNKNOWN;

  345. }

  346. }

  347. privatestaticintgetNetworkClass(){

  348. intnetworkType=NETWORK_TYPE_UNKNOWN;

  349. try{

  350. finalNetworkInfonetwork=((ConnectivityManager)ConfigManager

  351. .getContext()

  352. .getSystemService(Context.CONNECTIVITY_SERVICE))

  353. .getActiveNetworkInfo();

  354. if(network!=null&&network.isAvailable()

  355. &&network.isConnected()){

  356. inttype=network.getType();

  357. if(type==ConnectivityManager.TYPE_WIFI){

  358. networkType=NETWORK_TYPE_WIFI;

  359. }elseif(type==ConnectivityManager.TYPE_MOBILE){

  360. TelephonyManagertelephonyManager=(TelephonyManager)ConfigManager

  361. .getContext().getSystemService(

  362. Context.TELEPHONY_SERVICE);

  363. networkType=telephonyManager.getNetworkType();

  364. }

  365. }else{

  366. networkType=NETWORK_TYPE_UNAVAILABLE;

  367. }

  368. }catch(Exceptionex){

  369. ex.printStackTrace();

  370. }

  371. returngetNetworkClassByType(networkType);

  372. }

  373. publicstaticStringgetWifiRssi(){

  374. intasu=85;

  375. try{

  376. finalNetworkInfonetwork=((ConnectivityManager)ConfigManager

  377. .getContext()

  378. .getSystemService(Context.CONNECTIVITY_SERVICE))

  379. .getActiveNetworkInfo();

  380. if(network!=null&&network.isAvailable()

  381. &&network.isConnected()){

  382. inttype=network.getType();

  383. if(type==ConnectivityManager.TYPE_WIFI){

  384. WifiManagerwifiManager=(WifiManager)ConfigManager

  385. .getContext()

  386. .getSystemService(Context.WIFI_SERVICE);

  387. WifiInfowifiInfo=wifiManager.getConnectionInfo();

  388. if(wifiInfo!=null){

  389. asu=wifiInfo.getRssi();

  390. }

  391. }

  392. }

  393. }catch(Exceptione){

  394. e.printStackTrace();

  395. }

  396. returnasu+"dBm";

  397. }

  398. publicstaticStringgetWifiSsid(){

  399. Stringssid="";

  400. try{

  401. finalNetworkInfonetwork=((ConnectivityManager)ConfigManager

  402. .getContext()

  403. .getSystemService(Context.CONNECTIVITY_SERVICE))

  404. .getActiveNetworkInfo();

  405. if(network!=null&&network.isAvailable()

  406. &&network.isConnected()){

  407. inttype=network.getType();

  408. if(type==ConnectivityManager.TYPE_WIFI){

  409. WifiManagerwifiManager=(WifiManager)ConfigManager

  410. .getContext()

  411. .getSystemService(Context.WIFI_SERVICE);

  412. WifiInfowifiInfo=wifiManager.getConnectionInfo();

  413. if(wifiInfo!=null){

  414. ssid=wifiInfo.getSSID();

  415. if(ssid==null){

  416. ssid="";

  417. }

  418. ssid=ssid.replaceAll("\"","");

  419. }

  420. }

  421. }

  422. }catch(Exceptione){

  423. e.printStackTrace();

  424. }

  425. returnssid;

  426. }

  427. /**

  428. *检查sim卡状态

  429. *

  430. *@paramctx

  431. *@return

  432. */

  433. publicstaticbooleancheckSimState(){

  434. TelephonyManagertm=(TelephonyManager)ConfigManager.getContext()

  435. .getSystemService(Context.TELEPHONY_SERVICE);

  436. if(tm.getSimState()==TelephonyManager.SIM_STATE_ABSENT

  437. ||tm.getSimState()==TelephonyManager.SIM_STATE_UNKNOWN){

  438. returnfalse;

  439. }

  440. returntrue;

  441. }

  442. /**

  443. *获取imei

  444. */

  445. publicstaticStringgetImei(){

  446. TelephonyManagermTelephonyMgr=(TelephonyManager)ConfigManager

  447. .getContext().getSystemService(Context.TELEPHONY_SERVICE);

  448. Stringimei=mTelephonyMgr.getDeviceId();

  449. if(imei==null){

  450. imei="000000000000000";

  451. }

  452. returnimei;

  453. }

  454. publicstaticStringgetPhoneImsi(){

  455. TelephonyManagermTelephonyMgr=(TelephonyManager)ConfigManager

  456. .getContext().getSystemService(Context.TELEPHONY_SERVICE);

  457. returnmTelephonyMgr.getSubscriberId();

  458. }

  459. publicstaticCellInfogetNetInfo(){

  460. CellInfoinfo=newCellInfo();

  461. try{

  462. TelephonyManagermTelephonyManager=(TelephonyManager)ConfigManager

  463. .getContext().getSystemService(Context.TELEPHONY_SERVICE);

  464. Stringoperator=mTelephonyManager.getNetworkOperator();

  465. if(operator!=null){

  466. /**通过operator获取MCC和MNC*/

  467. if(operator.length()>3){

  468. Stringmcc=operator.substring(0,3);

  469. Stringmnc=operator.substring(3);

  470. info.setMcc(mcc);

  471. info.setMnc(mnc);

  472. }

  473. }

  474. intlac=0;

  475. intcellId=0;

  476. intphoneType=mTelephonyManager.getPhoneType();

  477. if(phoneType==TelephonyManager.PHONE_TYPE_GSM){

  478. GsmCellLocationlocation=(GsmCellLocation)mTelephonyManager

  479. .getCellLocation();

  480. /**通过GsmCellLocation获取中国移动和联通LAC和cellID*/

  481. lac=location.getLac();

  482. cellId=location.getCid();

  483. }elseif(phoneType==TelephonyManager.PHONE_TYPE_CDMA){

  484. CdmaCellLocationlocation=(CdmaCellLocation)mTelephonyManager

  485. .getCellLocation();

  486. lac=location.getNetworkId();

  487. cellId=location.getBaseStationId();

  488. cellId/=16;

  489. }

  490. if(lac==0||cellId==0){

  491. List<NeighboringCellInfo>infos=mTelephonyManager

  492. .getNeighboringCellInfo();

  493. intlc=0;

  494. intci=0;

  495. intrssi=0;

  496. for(NeighboringCellInfocell:infos){

  497. //根据邻区总数进行循环

  498. if(lc==0||ci==0){

  499. lc=cell.getLac();

  500. ci=cell.getCid();

  501. rssi=cell.getRssi();

  502. }

  503. //sb.append("LAC:"+info.getLac());

  504. ////取出当前邻区的LAC

  505. //sb.append("CID:"+info.getCid());

  506. ////取出当前邻区的CID

  507. //sb.append("BSSS:"+(-113+2*info.getRssi())+

  508. //"\n");//获取邻区基站信号强度

  509. }

  510. rssi=-113+2*rssi;

  511. }

  512. }catch(Exceptione){

  513. e.printStackTrace();

  514. }

  515. returninfo;

  516. }

  517. }



更多相关文章

  1. Nginx系列教程(六)| 手把手教你搭建 LNMP 架构并部署天空网络电影
  2. 解决下载Android4.0源码时遇到的问题
  3. Android(安卓)模拟器解决公司网络内无法上网的另类解决方法
  4. Android中的沙箱模型
  5. Android网络编程之——Android下菜单系统模块的实现(Android客户
  6. Android解决用户多次点击按钮问题
  7. Android基于HTTP网络编程总结浅析
  8. Android(安卓)App 中简易的网络数据处理方法
  9. Android再按一次退出应用

随机推荐

  1. android Linux常用命令
  2. android 获取设备支持的编解码器的方法
  3. [转载]android下activity中两个listview
  4. Android开发必备的21个免费资源和工具
  5. android wheel实现各种选择效果
  6. linux tar.gz zip 减压 压缩命令
  7. Android Glide缓存清除与获取缓存大小
  8. android 存储方法一SharedPreferences存
  9. Android ViewPager多页面滑动切换以及底
  10. Android触摸事件传递(上)