Android 11 (SDK স্তর 30) এবং উচ্চতর, অ্যাপগুলি android.provider.Settings.ACTION_WIFI_ADD_NETWORKS
ব্যবহার করে ব্যবহারকারীকে এক বা একাধিক নতুন সংরক্ষিত নেটওয়ার্ক বা পাসপয়েন্ট কনফিগারেশন যোগ করার মাধ্যমে গাইড করতে পারে৷ এপিআই বিদ্যমান সংরক্ষিত কনফিগারেশনগুলিকে সংশোধন করার জন্যও কাজ করে।
একটি নেটওয়ার্ক বা পাসপয়েন্ট কনফিগারেশন সংরক্ষণ করতে, নিম্নলিখিতগুলি করুন:
একটি
ACTION_WIFI_ADD_NETWORKS
অভিপ্রায় তৈরি করুন৷WifiNetworkSuggestion.Builder
ব্যবহার করে এক বা একাধিক কনফিগারেশন তৈরি করুন। মনে রাখবেন যে আপনি একটিWifiNetworkSuggestion
ব্যবহার করলেও, এই Intent API সাজেশন API এর সাথে সম্পর্কিত নয়।কনফিগারেশনগুলির একটি পার্সেলযোগ্য অ্যারে তালিকা তৈরি করুন এবং এটিকে
EXTRA_WIFI_NETWORK_LIST
অতিরিক্ত দিয়ে অভিপ্রায়ে সংযুক্ত করুন৷Activity.startActivityForResult()
এক্সিকিউট করুন, উদ্দেশ্য পাস করা।Activity.onActivityResult()
কলব্যাক ব্যবহার করে ফলাফলের জন্য শুনুন।resultCode
নিম্নলিখিতগুলির মধ্যে একটি হতে পারে:-
Activity.RESULT_OK
: নির্দেশ করে যে ব্যবহারকারী প্রস্তাবিত নেটওয়ার্কগুলি গ্রহণ করেছে এবং সেগুলি সংরক্ষণ করেছে৷ -
Activity.RESULT_CANCELED
: নির্দেশ করে যে ব্যবহারকারী প্রস্তাবিত নেটওয়ার্কগুলি প্রত্যাখ্যান করেছে৷
resultCode
যদিRESULT_OK
হয়, তাহলে ডেটাIntent
EXTRA_WIFI_NETWORK_RESULT_LIST
অতিরিক্ত রয়েছে, যার মধ্যে ফলাফল কোডের একটি অ্যারে রয়েছে যা নির্দেশ করে যে পৃথক কনফিগারেশনগুলি সফলভাবে সংরক্ষিত হয়েছে কিনা। সম্ভাব্য ফলাফল কোড হল:-
ADD_WIFI_RESULT_SUCCESS
: কনফিগারেশন যোগ করা হয়েছে বা সফলভাবে আপডেট হয়েছে৷ -
ADD_WIFI_RESULT_ADD_OR_UPDATE_FAILED
: কনফিগারেশন যোগ করার চেষ্টা করার সময় ব্যর্থতা, যেমন একটি খারাপভাবে গঠিত কনফিগারেশনের কারণে। -
ADD_WIFI_RESULT_ALREADY_EXISTS
: অনুরোধ করা কনফিগারেশনটি ইতিমধ্যেই বিদ্যমান তাই কোনো পদক্ষেপের প্রয়োজন ছিল না।
-
অনুরোধটি সফল হলে, প্ল্যাটফর্মটি নতুন সংরক্ষিত নেটওয়ার্কগুলির একটিতে একটি সংযোগ চালু করে।
কোড নমুনা
নিম্নলিখিত কোড নমুনা দেখায় কিভাবে একটি নেটওয়ার্ক বা পাসপয়েন্ট কনফিগারেশন সংরক্ষণ করতে হয়।
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
...
}
fun startOperation() {
val suggestions = ArrayList<WifiNetworkSuggestion>()
// WPA2 configuration
suggestions.add(
WifiNetworkSuggestion.Builder()
.setSsid("test111111")
.setWpa2Passphrase("test123456")
.build()
)
// Open configuration
suggestions.add(
WifiNetworkSuggestion.Builder()
.setSsid("test222222")
.build()
)
// Passpoint configuration
val config = PasspointConfiguration()
config.credential = Credential().apply {
realm = "realm.example.com"
simCredential = Credential.SimCredential().apply {
eapType = 18
imsi = "123456*"
}
}
config.homeSp = HomeSp().apply {
fqdn = "test1.example.com"
friendlyName = "Some Friendly Name"
}
suggestions.add(
WifiNetworkSuggestion.Builder()
.setPasspointConfig(config)
.build())
// Create intent
val bundle = Bundle()
bundle.putParcelableArrayList(EXTRA_WIFI_NETWORK_LIST, suggestions)
val intent = Intent(ACTION_WIFI_ADD_NETWORKS)
intent.putExtras(bundle)
// Launch intent
startActivityForResult(intent, 0)
}
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
if(resultCode == RESULT_OK) {
// user agreed to save configurations: still need to check individual results
if (data != null && data.hasExtra(EXTRA_WIFI_NETWORK_RESULT_LIST)) {
for (code in data.getIntegerArrayListExtra(EXTRA_WIFI_NETWORK_RESULT_LIST)) {
when (code) {
ADD_WIFI_RESULT_SUCCESS ->
... // Configuration saved or modified
ADD_WIFI_RESULT_ADD_OR_UPDATE_FAILED ->
... // Something went wrong - invalid configuration
ADD_WIFI_RESULT_ALREADY_EXISTS ->
... // Configuration existed (as-is) on device, nothing changed
else ->
... // Other errors
}
}
}
} else {
// User refused to save configurations
}
}
}
Android 11 (SDK স্তর 30) এবং উচ্চতর, অ্যাপগুলি android.provider.Settings.ACTION_WIFI_ADD_NETWORKS
ব্যবহার করে ব্যবহারকারীকে এক বা একাধিক নতুন সংরক্ষিত নেটওয়ার্ক বা পাসপয়েন্ট কনফিগারেশন যোগ করার মাধ্যমে গাইড করতে পারে৷ এপিআই বিদ্যমান সংরক্ষিত কনফিগারেশনগুলিকে সংশোধন করার জন্যও কাজ করে।
একটি নেটওয়ার্ক বা পাসপয়েন্ট কনফিগারেশন সংরক্ষণ করতে, নিম্নলিখিতগুলি করুন:
একটি
ACTION_WIFI_ADD_NETWORKS
অভিপ্রায় তৈরি করুন৷WifiNetworkSuggestion.Builder
ব্যবহার করে এক বা একাধিক কনফিগারেশন তৈরি করুন। মনে রাখবেন যে আপনি একটিWifiNetworkSuggestion
ব্যবহার করলেও, এই Intent API সাজেশন API এর সাথে সম্পর্কিত নয়।কনফিগারেশনগুলির একটি পার্সেলযোগ্য অ্যারে তালিকা তৈরি করুন এবং এটিকে
EXTRA_WIFI_NETWORK_LIST
অতিরিক্ত দিয়ে অভিপ্রায়ে সংযুক্ত করুন৷Activity.startActivityForResult()
এক্সিকিউট করুন, উদ্দেশ্য পাস করা।Activity.onActivityResult()
কলব্যাক ব্যবহার করে ফলাফলের জন্য শুনুন।resultCode
নিম্নলিখিতগুলির মধ্যে একটি হতে পারে:-
Activity.RESULT_OK
: নির্দেশ করে যে ব্যবহারকারী প্রস্তাবিত নেটওয়ার্কগুলি গ্রহণ করেছে এবং সেগুলি সংরক্ষণ করেছে৷ -
Activity.RESULT_CANCELED
: নির্দেশ করে যে ব্যবহারকারী প্রস্তাবিত নেটওয়ার্কগুলি প্রত্যাখ্যান করেছে৷
resultCode
যদিRESULT_OK
হয়, তাহলে ডেটাIntent
EXTRA_WIFI_NETWORK_RESULT_LIST
অতিরিক্ত রয়েছে, যার মধ্যে ফলাফল কোডের একটি অ্যারে রয়েছে যা নির্দেশ করে যে পৃথক কনফিগারেশনগুলি সফলভাবে সংরক্ষিত হয়েছে কিনা। সম্ভাব্য ফলাফল কোড হল:-
ADD_WIFI_RESULT_SUCCESS
: কনফিগারেশন যোগ করা হয়েছে বা সফলভাবে আপডেট হয়েছে৷ -
ADD_WIFI_RESULT_ADD_OR_UPDATE_FAILED
: কনফিগারেশন যোগ করার চেষ্টা করার সময় ব্যর্থতা, যেমন একটি খারাপভাবে গঠিত কনফিগারেশনের কারণে। -
ADD_WIFI_RESULT_ALREADY_EXISTS
: অনুরোধ করা কনফিগারেশনটি ইতিমধ্যেই বিদ্যমান তাই কোনো পদক্ষেপের প্রয়োজন ছিল না।
-
অনুরোধটি সফল হলে, প্ল্যাটফর্মটি নতুন সংরক্ষিত নেটওয়ার্কগুলির একটিতে একটি সংযোগ চালু করে।
কোড নমুনা
নিম্নলিখিত কোড নমুনা দেখায় কিভাবে একটি নেটওয়ার্ক বা পাসপয়েন্ট কনফিগারেশন সংরক্ষণ করতে হয়।
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
...
}
fun startOperation() {
val suggestions = ArrayList<WifiNetworkSuggestion>()
// WPA2 configuration
suggestions.add(
WifiNetworkSuggestion.Builder()
.setSsid("test111111")
.setWpa2Passphrase("test123456")
.build()
)
// Open configuration
suggestions.add(
WifiNetworkSuggestion.Builder()
.setSsid("test222222")
.build()
)
// Passpoint configuration
val config = PasspointConfiguration()
config.credential = Credential().apply {
realm = "realm.example.com"
simCredential = Credential.SimCredential().apply {
eapType = 18
imsi = "123456*"
}
}
config.homeSp = HomeSp().apply {
fqdn = "test1.example.com"
friendlyName = "Some Friendly Name"
}
suggestions.add(
WifiNetworkSuggestion.Builder()
.setPasspointConfig(config)
.build())
// Create intent
val bundle = Bundle()
bundle.putParcelableArrayList(EXTRA_WIFI_NETWORK_LIST, suggestions)
val intent = Intent(ACTION_WIFI_ADD_NETWORKS)
intent.putExtras(bundle)
// Launch intent
startActivityForResult(intent, 0)
}
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
if(resultCode == RESULT_OK) {
// user agreed to save configurations: still need to check individual results
if (data != null && data.hasExtra(EXTRA_WIFI_NETWORK_RESULT_LIST)) {
for (code in data.getIntegerArrayListExtra(EXTRA_WIFI_NETWORK_RESULT_LIST)) {
when (code) {
ADD_WIFI_RESULT_SUCCESS ->
... // Configuration saved or modified
ADD_WIFI_RESULT_ADD_OR_UPDATE_FAILED ->
... // Something went wrong - invalid configuration
ADD_WIFI_RESULT_ALREADY_EXISTS ->
... // Configuration existed (as-is) on device, nothing changed
else ->
... // Other errors
}
}
}
} else {
// User refused to save configurations
}
}
}
Android 11 (SDK স্তর 30) এবং উচ্চতর, অ্যাপগুলি android.provider.Settings.ACTION_WIFI_ADD_NETWORKS
ব্যবহার করে ব্যবহারকারীকে এক বা একাধিক নতুন সংরক্ষিত নেটওয়ার্ক বা পাসপয়েন্ট কনফিগারেশন যোগ করার মাধ্যমে গাইড করতে পারে৷ এপিআই বিদ্যমান সংরক্ষিত কনফিগারেশনগুলিকে সংশোধন করার জন্যও কাজ করে।
একটি নেটওয়ার্ক বা পাসপয়েন্ট কনফিগারেশন সংরক্ষণ করতে, নিম্নলিখিতগুলি করুন:
একটি
ACTION_WIFI_ADD_NETWORKS
অভিপ্রায় তৈরি করুন৷WifiNetworkSuggestion.Builder
ব্যবহার করে এক বা একাধিক কনফিগারেশন তৈরি করুন। মনে রাখবেন যে আপনি একটিWifiNetworkSuggestion
ব্যবহার করলেও, এই Intent API সাজেশন API এর সাথে সম্পর্কিত নয়।কনফিগারেশনগুলির একটি পার্সেলযোগ্য অ্যারে তালিকা তৈরি করুন এবং এটিকে
EXTRA_WIFI_NETWORK_LIST
অতিরিক্ত দিয়ে অভিপ্রায়ে সংযুক্ত করুন৷Activity.startActivityForResult()
এক্সিকিউট করুন, উদ্দেশ্য পাস করা।Activity.onActivityResult()
কলব্যাক ব্যবহার করে ফলাফলের জন্য শুনুন।resultCode
নিম্নলিখিতগুলির মধ্যে একটি হতে পারে:-
Activity.RESULT_OK
: নির্দেশ করে যে ব্যবহারকারী প্রস্তাবিত নেটওয়ার্কগুলি গ্রহণ করেছে এবং সেগুলি সংরক্ষণ করেছে৷ -
Activity.RESULT_CANCELED
: নির্দেশ করে যে ব্যবহারকারী প্রস্তাবিত নেটওয়ার্কগুলি প্রত্যাখ্যান করেছে৷
resultCode
যদিRESULT_OK
হয়, তাহলে ডেটাIntent
EXTRA_WIFI_NETWORK_RESULT_LIST
অতিরিক্ত রয়েছে, যার মধ্যে ফলাফল কোডের একটি অ্যারে রয়েছে যা নির্দেশ করে যে পৃথক কনফিগারেশনগুলি সফলভাবে সংরক্ষিত হয়েছে কিনা। সম্ভাব্য ফলাফল কোড হল:-
ADD_WIFI_RESULT_SUCCESS
: কনফিগারেশন যোগ করা হয়েছে বা সফলভাবে আপডেট হয়েছে৷ -
ADD_WIFI_RESULT_ADD_OR_UPDATE_FAILED
: কনফিগারেশন যোগ করার চেষ্টা করার সময় ব্যর্থতা, যেমন একটি খারাপভাবে গঠিত কনফিগারেশনের কারণে। -
ADD_WIFI_RESULT_ALREADY_EXISTS
: অনুরোধ করা কনফিগারেশনটি ইতিমধ্যেই বিদ্যমান তাই কোনো পদক্ষেপের প্রয়োজন ছিল না।
-
অনুরোধটি সফল হলে, প্ল্যাটফর্মটি নতুন সংরক্ষিত নেটওয়ার্কগুলির একটিতে একটি সংযোগ চালু করে।
কোড নমুনা
নিম্নলিখিত কোড নমুনা দেখায় কিভাবে একটি নেটওয়ার্ক বা পাসপয়েন্ট কনফিগারেশন সংরক্ষণ করতে হয়।
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
...
}
fun startOperation() {
val suggestions = ArrayList<WifiNetworkSuggestion>()
// WPA2 configuration
suggestions.add(
WifiNetworkSuggestion.Builder()
.setSsid("test111111")
.setWpa2Passphrase("test123456")
.build()
)
// Open configuration
suggestions.add(
WifiNetworkSuggestion.Builder()
.setSsid("test222222")
.build()
)
// Passpoint configuration
val config = PasspointConfiguration()
config.credential = Credential().apply {
realm = "realm.example.com"
simCredential = Credential.SimCredential().apply {
eapType = 18
imsi = "123456*"
}
}
config.homeSp = HomeSp().apply {
fqdn = "test1.example.com"
friendlyName = "Some Friendly Name"
}
suggestions.add(
WifiNetworkSuggestion.Builder()
.setPasspointConfig(config)
.build())
// Create intent
val bundle = Bundle()
bundle.putParcelableArrayList(EXTRA_WIFI_NETWORK_LIST, suggestions)
val intent = Intent(ACTION_WIFI_ADD_NETWORKS)
intent.putExtras(bundle)
// Launch intent
startActivityForResult(intent, 0)
}
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
if(resultCode == RESULT_OK) {
// user agreed to save configurations: still need to check individual results
if (data != null && data.hasExtra(EXTRA_WIFI_NETWORK_RESULT_LIST)) {
for (code in data.getIntegerArrayListExtra(EXTRA_WIFI_NETWORK_RESULT_LIST)) {
when (code) {
ADD_WIFI_RESULT_SUCCESS ->
... // Configuration saved or modified
ADD_WIFI_RESULT_ADD_OR_UPDATE_FAILED ->
... // Something went wrong - invalid configuration
ADD_WIFI_RESULT_ALREADY_EXISTS ->
... // Configuration existed (as-is) on device, nothing changed
else ->
... // Other errors
}
}
}
} else {
// User refused to save configurations
}
}
}
Android 11 (SDK স্তর 30) এবং উচ্চতর, অ্যাপগুলি android.provider.Settings.ACTION_WIFI_ADD_NETWORKS
ব্যবহার করে ব্যবহারকারীকে এক বা একাধিক নতুন সংরক্ষিত নেটওয়ার্ক বা পাসপয়েন্ট কনফিগারেশন যোগ করার মাধ্যমে গাইড করতে পারে৷ এপিআই বিদ্যমান সংরক্ষিত কনফিগারেশনগুলিকে সংশোধন করার জন্যও কাজ করে।
একটি নেটওয়ার্ক বা পাসপয়েন্ট কনফিগারেশন সংরক্ষণ করতে, নিম্নলিখিতগুলি করুন:
একটি
ACTION_WIFI_ADD_NETWORKS
অভিপ্রায় তৈরি করুন৷WifiNetworkSuggestion.Builder
ব্যবহার করে এক বা একাধিক কনফিগারেশন তৈরি করুন। মনে রাখবেন যে আপনি একটিWifiNetworkSuggestion
ব্যবহার করলেও, এই Intent API সাজেশন API এর সাথে সম্পর্কিত নয়।কনফিগারেশনগুলির একটি পার্সেলযোগ্য অ্যারে তালিকা তৈরি করুন এবং এটিকে
EXTRA_WIFI_NETWORK_LIST
অতিরিক্ত দিয়ে অভিপ্রায়ে সংযুক্ত করুন৷Activity.startActivityForResult()
এক্সিকিউট করুন, উদ্দেশ্য পাস করা।Activity.onActivityResult()
কলব্যাক ব্যবহার করে ফলাফলের জন্য শুনুন।resultCode
নিম্নলিখিতগুলির মধ্যে একটি হতে পারে:-
Activity.RESULT_OK
: নির্দেশ করে যে ব্যবহারকারী প্রস্তাবিত নেটওয়ার্কগুলি গ্রহণ করেছে এবং সেগুলি সংরক্ষণ করেছে৷ -
Activity.RESULT_CANCELED
: নির্দেশ করে যে ব্যবহারকারী প্রস্তাবিত নেটওয়ার্কগুলি প্রত্যাখ্যান করেছে৷
resultCode
যদিRESULT_OK
হয়, তাহলে ডেটাIntent
EXTRA_WIFI_NETWORK_RESULT_LIST
অতিরিক্ত রয়েছে, যার মধ্যে ফলাফল কোডের একটি অ্যারে রয়েছে যা নির্দেশ করে যে পৃথক কনফিগারেশনগুলি সফলভাবে সংরক্ষিত হয়েছে কিনা। সম্ভাব্য ফলাফল কোড হল:-
ADD_WIFI_RESULT_SUCCESS
: কনফিগারেশন যোগ করা হয়েছে বা সফলভাবে আপডেট হয়েছে৷ -
ADD_WIFI_RESULT_ADD_OR_UPDATE_FAILED
: কনফিগারেশন যোগ করার চেষ্টা করার সময় ব্যর্থতা, যেমন একটি খারাপভাবে গঠিত কনফিগারেশনের কারণে। -
ADD_WIFI_RESULT_ALREADY_EXISTS
: অনুরোধ করা কনফিগারেশনটি ইতিমধ্যেই বিদ্যমান তাই কোনো পদক্ষেপের প্রয়োজন ছিল না।
-
অনুরোধটি সফল হলে, প্ল্যাটফর্মটি নতুন সংরক্ষিত নেটওয়ার্কগুলির একটিতে একটি সংযোগ চালু করে।
কোড নমুনা
নিম্নলিখিত কোড নমুনা দেখায় কিভাবে একটি নেটওয়ার্ক বা পাসপয়েন্ট কনফিগারেশন সংরক্ষণ করতে হয়।
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
...
}
fun startOperation() {
val suggestions = ArrayList<WifiNetworkSuggestion>()
// WPA2 configuration
suggestions.add(
WifiNetworkSuggestion.Builder()
.setSsid("test111111")
.setWpa2Passphrase("test123456")
.build()
)
// Open configuration
suggestions.add(
WifiNetworkSuggestion.Builder()
.setSsid("test222222")
.build()
)
// Passpoint configuration
val config = PasspointConfiguration()
config.credential = Credential().apply {
realm = "realm.example.com"
simCredential = Credential.SimCredential().apply {
eapType = 18
imsi = "123456*"
}
}
config.homeSp = HomeSp().apply {
fqdn = "test1.example.com"
friendlyName = "Some Friendly Name"
}
suggestions.add(
WifiNetworkSuggestion.Builder()
.setPasspointConfig(config)
.build())
// Create intent
val bundle = Bundle()
bundle.putParcelableArrayList(EXTRA_WIFI_NETWORK_LIST, suggestions)
val intent = Intent(ACTION_WIFI_ADD_NETWORKS)
intent.putExtras(bundle)
// Launch intent
startActivityForResult(intent, 0)
}
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
if(resultCode == RESULT_OK) {
// user agreed to save configurations: still need to check individual results
if (data != null && data.hasExtra(EXTRA_WIFI_NETWORK_RESULT_LIST)) {
for (code in data.getIntegerArrayListExtra(EXTRA_WIFI_NETWORK_RESULT_LIST)) {
when (code) {
ADD_WIFI_RESULT_SUCCESS ->
... // Configuration saved or modified
ADD_WIFI_RESULT_ADD_OR_UPDATE_FAILED ->
... // Something went wrong - invalid configuration
ADD_WIFI_RESULT_ALREADY_EXISTS ->
... // Configuration existed (as-is) on device, nothing changed
else ->
... // Other errors
}
}
}
} else {
// User refused to save configurations
}
}
}