いつもお世話になっています。
今回、下記の関数でWifiの一覧を取得し、スピナーに表示したいと考えています。
ですが、実機で実行するとうまくいくものといかないものがあります。
うまくいく:KYOCERA KYY24(Android4.4)、samsung SC-04E(Android 5.0)
うまくいかない:KYOCERA KC-S702(Android7.1.2)
おそらくはSDKのバージョンによる違いで、KYOCERA KC-S702ではWifi情報が
取れていないのではないかと思うのですが、関数のどこが問題かわかりません。
現状の関数の問題点とそれをどう直すべきかについてアドバイスをお願いします。
MainActivity
1public void SettingSSIDList(){ 2 WifiManager manager = (WifiManager)getApplicationContext().getSystemService(WIFI_SERVICE); 3 ArrayList<String> aps = new ArrayList<>(); 4 aps.add("手入力"); 5 if(manager.getWifiState() == WifiManager.WIFI_STATE_ENABLED) { 6 // APをスキャン 7 manager.startScan(); 8 // スキャン結果を取得 9 List<ScanResult> apList = manager.getScanResults(); 10 for(int i=0; i<apList.size(); i++) { 11 aps.add(apList.get(i).SSID); 12 } 13 } 14 ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, aps); 15 spSSIDName.setAdapter(adapter); 16 }
Logcat
12019-12-20 11:30:29.740 1169-2486/? E/LOWI-7.7.2.5.b: [LOWIUtils] channelBandToFreq: Invalid band,channel = 1,0 22019-12-20 11:30:29.740 1169-2486/? E/LOWI-7.7.2.5.b: [LOWIUtils] channelBandToFreq: Invalid band,channel = 1,0 32019-12-20 11:30:29.740 1169-2486/? E/LOWI-7.7.2.5.b: [LOWIUtils] channelBandToFreq: Invalid band,channel = 1,0 42019-12-20 11:30:33.185 645-645/? E/cnss-daemon: Stale or unreachable neighbors, ndm state: 4 52019-12-20 11:30:42.486 1169-2486/? E/LOWI-7.7.2.5.b: [LOWIUtils] channelBandToFreq: Invalid band,channel = 1,0 62019-12-20 11:30:42.486 1169-2486/? E/LOWI-7.7.2.5.b: [LOWIUtils] channelBandToFreq: Invalid band,channel = 1,0 72019-12-20 11:30:42.486 1169-2486/? E/LOWI-7.7.2.5.b: [LOWIUtils] channelBandToFreq: Invalid band,channel = 1,0 82019-12-20 11:30:42.576 645-645/? E/cnss-daemon: Stale or unreachable neighbors, ndm state: 16 92019-12-20 11:30:56.106 645-645/? E/cnss-daemon: Stale or unreachable neighbors, ndm state: 4 102019-12-20 11:31:00.016 2216-5631/? E/ActivityManager: Sending non-protected broadcast com.kyocera.intent.action.WAKE_SERVICE_ACTION from system 2424:com.android.systemui/u0a31 pkg com.android.systemui 11 java.lang.Throwable 12 at com.android.server.am.ActivityManagerService.checkBroadcastFromSystem(ActivityManagerService.java:18321) 13 at com.android.server.am.ActivityManagerService.broadcastIntentLocked(ActivityManagerService.java:18893) 14 at com.android.server.am.ActivityManagerService.broadcastIntent(ActivityManagerService.java:18984) 15 at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:499) 16 at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2908) 17 at android.os.Binder.execTransact(Binder.java:565) 182019-12-20 11:31:01.176 645-645/? E/cnss-daemon: Stale or unreachable neighbors, ndm state: 16 192019-12-20 11:31:14.706 645-645/? E/cnss-daemon: Stale or unreachable neighbors, ndm state: 4 202019-12-20 11:31:19.865 645-645/? E/cnss-daemon: Stale or unreachable neighbors, ndm state: 16 21`` 22 23追記:下記記事を参考に「ACCESS_COARSE_LOCATION」のパーミッションが 24動的に取得せねばならないと知ったので、パーミッションを取得してから 25WifiScanを行うように改造しました。それでもやはりWifiが取れません。 26 27改造内容としてはパーミッションの取り方は下記の記事通りで、下記の記事のコードの 28logScanResults()をSettingSSIDList()に置き換えた形となります。 29 30https://kokufu.blogspot.com/2016/11/android-60-wifimanagergetscanresults.html
回答1件
あなたの回答
tips
プレビュー