Skip to content

Commit 21d7c6d

Browse files
Fest: Wifi Manager Wrapper In Kotlin, Implemented with listener
0 parents  commit 21d7c6d

35 files changed

+872
-0
lines changed

.gitignore

+49
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
1+
#built application files
2+
*.apk
3+
*.ap_
4+
5+
# files for the dex VM
6+
*.dex
7+
8+
# Java class files
9+
*.class
10+
11+
# generated files
12+
bin/
13+
gen/
14+
15+
# Local configuration file (sdk path, etc)
16+
local.properties
17+
18+
# Windows thumbnail db
19+
Thumbs.db
20+
21+
# OSX files
22+
.DS_Store
23+
24+
# Android Studio
25+
*.iml
26+
.idea
27+
#.idea/workspace.xml - remove # and delete .idea if it better suit your needs.
28+
.gradle
29+
build/
30+
.navigation
31+
captures/
32+
output.json
33+
34+
#NDK
35+
obj/
36+
.externalNativeBuild
37+
38+
39+
/local.properties
40+
/.idea/caches
41+
/.idea/libraries
42+
/.idea/modules.xml
43+
/.idea/workspace.xml
44+
/.idea/navEditor.xml
45+
/.idea/assetWizardSettings.xml
46+
/build
47+
/captures
48+
.cxx
49+

app/.gitignore

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
/build

app/build.gradle

+37
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
apply plugin: 'com.android.application'
2+
apply plugin: 'kotlin-android'
3+
apply plugin: 'kotlin-android-extensions'
4+
5+
android {
6+
compileSdkVersion 29
7+
buildToolsVersion "29.0.3"
8+
9+
defaultConfig {
10+
applicationId "com.imake.wifimanagerwrapper"
11+
minSdkVersion 21
12+
targetSdkVersion 29
13+
versionCode 1
14+
versionName "1.0"
15+
16+
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
17+
}
18+
19+
buildTypes {
20+
release {
21+
minifyEnabled false
22+
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
23+
}
24+
}
25+
26+
}
27+
28+
dependencies {
29+
implementation fileTree(dir: 'libs', include: ['*.jar'])
30+
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
31+
implementation 'androidx.appcompat:appcompat:1.1.0'
32+
implementation 'androidx.core:core-ktx:1.2.0'
33+
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
34+
testImplementation 'junit:junit:4.12'
35+
androidTestImplementation 'androidx.test.ext:junit:1.1.1'
36+
androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'
37+
}

app/proguard-rules.pro

+21
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
# Add project specific ProGuard rules here.
2+
# You can control the set of applied configuration files using the
3+
# proguardFiles setting in build.gradle.
4+
#
5+
# For more details, see
6+
# http://developer.android.com/guide/developing/tools/proguard.html
7+
8+
# If your project uses WebView with JS, uncomment the following
9+
# and specify the fully qualified class name to the JavaScript interface
10+
# class:
11+
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
12+
# public *;
13+
#}
14+
15+
# Uncomment this to preserve the line number information for
16+
# debugging stack traces.
17+
#-keepattributes SourceFile,LineNumberTable
18+
19+
# If you keep the line number information, uncomment this to
20+
# hide the original source file name.
21+
#-renamesourcefileattribute SourceFile
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
package com.imake.wifimanagerwrapper
2+
3+
import androidx.test.platform.app.InstrumentationRegistry
4+
import androidx.test.ext.junit.runners.AndroidJUnit4
5+
6+
import org.junit.Test
7+
import org.junit.runner.RunWith
8+
9+
import org.junit.Assert.*
10+
11+
/**
12+
* Instrumented test, which will execute on an Android device.
13+
*
14+
* See [testing documentation](http://d.android.com/tools/testing).
15+
*/
16+
@RunWith(AndroidJUnit4::class)
17+
class ExampleInstrumentedTest {
18+
@Test
19+
fun useAppContext() {
20+
// Context of the app under test.
21+
val appContext = InstrumentationRegistry.getInstrumentation().targetContext
22+
assertEquals("com.imake.wifimanagerwrapper", appContext.packageName)
23+
}
24+
}

app/src/main/AndroidManifest.xml

+26
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
3+
xmlns:tools="http://schemas.android.com/tools"
4+
package="com.imake.wifimanagerwrapper">
5+
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
6+
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
7+
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
8+
9+
<application
10+
android:allowBackup="true"
11+
android:icon="@mipmap/ic_launcher"
12+
android:label="@string/app_name"
13+
android:roundIcon="@mipmap/ic_launcher_round"
14+
android:supportsRtl="true"
15+
android:usesCleartextTraffic="true"
16+
android:theme="@style/AppTheme"
17+
tools:targetApi="m">
18+
<activity android:name=".MainActivity">
19+
<intent-filter>
20+
<action android:name="android.intent.action.MAIN" />
21+
<category android:name="android.intent.category.LAUNCHER" />
22+
</intent-filter>
23+
</activity>
24+
</application>
25+
26+
</manifest>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
package com.imake.wifimanagerwrapper
2+
3+
import android.net.wifi.ScanResult
4+
import androidx.appcompat.app.AppCompatActivity
5+
import android.os.Bundle
6+
import android.view.View
7+
import com.imake.waterlevel.util.wifiwrapper.WifiCallbackResult
8+
import com.imake.wifimanagerwrapper.util.wifiwrapper.WifiManagerWrapper
9+
import kotlinx.android.synthetic.main.activity_main.*
10+
11+
class MainActivity : AppCompatActivity(), WifiCallbackResult {
12+
13+
override fun onCreate(savedInstanceState: Bundle?) {
14+
super.onCreate(savedInstanceState)
15+
setContentView(R.layout.activity_main)
16+
scanBtn.setOnClickListener {
17+
WifiManagerWrapper().wifiManagerInti(it.context,this)
18+
}
19+
}
20+
21+
override fun wifiFailureResult(results: MutableList<ScanResult>) {
22+
println("wifiFailureResult*****************rootTemp = ${results}")
23+
}
24+
25+
override fun wifiSuccessResult(results: List<ScanResult>) {
26+
println("wifiSuccessResult******************rootTemp = ${results}")
27+
}
28+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
package com.imake.waterlevel.util.wifiwrapper
2+
3+
import android.net.wifi.ScanResult
4+
5+
interface WifiCallbackResult {
6+
fun wifiFailureResult(results: MutableList<ScanResult>);
7+
fun wifiSuccessResult(results: List<ScanResult>)
8+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,85 @@
1+
package com.imake.wifimanagerwrapper.util.wifiwrapper
2+
3+
import android.content.BroadcastReceiver
4+
import android.content.Context
5+
import android.content.Intent
6+
import android.content.IntentFilter
7+
import android.net.wifi.WifiManager
8+
import android.os.Build
9+
import androidx.annotation.RequiresApi
10+
import com.imake.waterlevel.util.wifiwrapper.WifiCallbackResult
11+
12+
class WifiManagerWrapper() {
13+
private lateinit var listenerCallback: WifiCallbackResult
14+
private lateinit var context: Context
15+
private lateinit var wifiScanReceiver: BroadcastReceiver
16+
private lateinit var wifiManager: WifiManager
17+
18+
19+
fun wifiManagerInti(contextInti: Context, listener: WifiCallbackResult) {
20+
this.listenerCallback = listener
21+
this.context = contextInti.applicationContext
22+
wifiManager =
23+
context.applicationContext.getSystemService(Context.WIFI_SERVICE) as WifiManager
24+
println("wifiManager.connectionInfo = ${wifiManager.connectionInfo}")
25+
if (wifiManager.isWifiEnabled)
26+
autoStartStopWifiScanner()
27+
}
28+
29+
private fun autoStartStopWifiScanner() {
30+
wifiBroadcastReceiverInstance()
31+
registerWifiBroadcastReceiver()
32+
val success = wifiManager.startScan()
33+
if (!success) {
34+
// scan failure handling
35+
unregisterWifiBroadcastReceiver()
36+
// println("***************scanFailure******************")
37+
scanFailure()
38+
}
39+
}
40+
41+
private fun startWifiScanner() {
42+
val success = wifiManager.startScan()
43+
if (!success) {
44+
// scan failure handling
45+
scanFailure()
46+
}
47+
}
48+
49+
private fun unregisterWifiBroadcastReceiver() {
50+
context.unregisterReceiver(wifiScanReceiver)
51+
}
52+
53+
private fun registerWifiBroadcastReceiver() {
54+
val intentFilter = IntentFilter()
55+
intentFilter.addAction(WifiManager.SCAN_RESULTS_AVAILABLE_ACTION)
56+
context.registerReceiver(wifiScanReceiver, intentFilter)
57+
}
58+
59+
private fun wifiBroadcastReceiverInstance() {
60+
wifiScanReceiver = object : BroadcastReceiver() {
61+
62+
@RequiresApi(Build.VERSION_CODES.M)
63+
override fun onReceive(context: Context, intent: Intent) {
64+
val success = intent.getBooleanExtra(WifiManager.EXTRA_RESULTS_UPDATED, false)
65+
if (success) {
66+
scanSuccess()
67+
} else {
68+
scanFailure()
69+
}
70+
}
71+
}
72+
}
73+
74+
private fun scanSuccess() {
75+
val results = wifiManager.scanResults
76+
listenerCallback.wifiSuccessResult(results)
77+
}
78+
79+
private fun scanFailure() {
80+
// handle failure: new scan did NOT succeed
81+
// consider using old scan results: these are the OLD results!
82+
val results = wifiManager.scanResults
83+
listenerCallback.wifiFailureResult(results)
84+
}
85+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,30 @@
1+
<vector xmlns:android="http://schemas.android.com/apk/res/android"
2+
xmlns:aapt="http://schemas.android.com/aapt"
3+
android:width="108dp"
4+
android:height="108dp"
5+
android:viewportWidth="108"
6+
android:viewportHeight="108">
7+
<path android:pathData="M31,63.928c0,0 6.4,-11 12.1,-13.1c7.2,-2.6 26,-1.4 26,-1.4l38.1,38.1L107,108.928l-32,-1L31,63.928z">
8+
<aapt:attr name="android:fillColor">
9+
<gradient
10+
android:endX="85.84757"
11+
android:endY="92.4963"
12+
android:startX="42.9492"
13+
android:startY="49.59793"
14+
android:type="linear">
15+
<item
16+
android:color="#44000000"
17+
android:offset="0.0" />
18+
<item
19+
android:color="#00000000"
20+
android:offset="1.0" />
21+
</gradient>
22+
</aapt:attr>
23+
</path>
24+
<path
25+
android:fillColor="#FFFFFF"
26+
android:fillType="nonZero"
27+
android:pathData="M65.3,45.828l3.8,-6.6c0.2,-0.4 0.1,-0.9 -0.3,-1.1c-0.4,-0.2 -0.9,-0.1 -1.1,0.3l-3.9,6.7c-6.3,-2.8 -13.4,-2.8 -19.7,0l-3.9,-6.7c-0.2,-0.4 -0.7,-0.5 -1.1,-0.3C38.8,38.328 38.7,38.828 38.9,39.228l3.8,6.6C36.2,49.428 31.7,56.028 31,63.928h46C76.3,56.028 71.8,49.428 65.3,45.828zM43.4,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2c-0.3,-0.7 -0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C45.3,56.528 44.5,57.328 43.4,57.328L43.4,57.328zM64.6,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2s-0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C66.5,56.528 65.6,57.328 64.6,57.328L64.6,57.328z"
28+
android:strokeWidth="1"
29+
android:strokeColor="#00000000" />
30+
</vector>

0 commit comments

Comments
 (0)