Passa ai contenuti principali

Android Studio - WebView: verifica della connessione (parte 3)

In questo articolo vedremo un esempio pratico su come verificare se il dispositivo è connesso ad internet.

Avevo già parlato in un precedente articolo su come verificare la connessione ad internet, la differenza sta nell'utilizzo di due Classi diverse a seconda della Versione SDK di Android.

Fino alla Versione SDK 22 (Android 5.1 - Android Lollipop) poteva andare bene la spiegazione nel precedente articolo nonostante in realtà funzionasse bene anche nelle versioni successive.
Dalla Versione SDK 23 (Android 6 - Android Marshmallow) è stata introdotta una nuova Classe (NetworkCapabilities) più specifica per queste versioni di Android e quindi non compatibile con le precedenti.

Quindi se la vostra app può essere installata su versioni precedenti ad Android 6 questa soluzione è la migliore.

Per verificare la connessione internet del dispositivo dobbiamo sempre aggiungere il permesso di accedere allo stato della connessione internet, per questo apriamo il file AndroidManifest.xml ed inseriamo questa riga di codice prima del tag application
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
Il risultato finale del file AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.dm.tutorialwebview11">
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/Theme.TutorialWebView11">
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
Ora è necessario aggiungere questa funzione al file MainActivity.kt subito dopo la funzione onCreate
private fun isConnected(context: Context): Boolean
{
val connectivityManager = context.getSystemService(Context.CONNECTIVITY_SERVICE) as ConnectivityManager
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
////per versioni Android uguali o superiori ad Android M (Android 6.0 - API 23)
val nw = connectivityManager.activeNetwork ?: return false
val actNw = connectivityManager.getNetworkCapabilities(nw) ?: return false
return when {
actNw.hasTransport(NetworkCapabilities.TRANSPORT_WIFI) -> true
actNw.hasTransport(NetworkCapabilities.TRANSPORT_CELLULAR) -> true
//per altri dispositivi che sono in grado di connettersi con Ethernet
actNw.hasTransport(NetworkCapabilities.TRANSPORT_ETHERNET) -> true
//per controllare la connessione Internet tramite Bluetooth
actNw.hasTransport(NetworkCapabilities.TRANSPORT_BLUETOOTH) -> true
else -> false
}
}
else //per versioni Android inferiori ad Android M (Android 6.0 - API 23)
{
return connectivityManager.activeNetworkInfo?.isConnected ?: false
}
}
Aggiungere poi questo controllo all'interno della funzione onCreate
if(isConnected(this))
{
//aggiungere qui eventuale codice da eseguire se il dispositivo è connesso ad internet
}
else
{
//aggiungere qui eventuale codice da eseguire se il dispositivo NON è connesso ad internet
Toast.makeText(this, "Non connesso ad internet", Toast.LENGTH_LONG).show()
}
Questo è il risultato finale del file MainActivity.kt
package com.dm.tutorialwebview11
import android.content.Context //Importazione della Classe: Context
import android.net.ConnectivityManager //Importazione della Classe: ConnectivityManager
import android.net.NetworkCapabilities //Importazione della Classe: NetworkCapabilities
import android.os.Build
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.webkit.WebChromeClient
import android.webkit.WebView
import android.webkit.WebViewClient
import android.widget.Toast
class MainActivity : AppCompatActivity() {
var webview: WebView? = null
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
webview = findViewById(R.id.myweb)
webview!!.webViewClient = WebViewClient()
webview!!.settings.javaScriptEnabled = true
webview!!.webChromeClient = WebChromeClient()
webview!!.settings.domStorageEnabled = true
webview!!.settings.builtInZoomControls = true
webview!!.settings.setSupportZoom(true)
webview!!.overScrollMode = WebView.OVER_SCROLL_NEVER
webview!!.settings.useWideViewPort = true
webview!!.setInitialScale(1)
webview!!.loadUrl("https://davidetech.blogspot.com")
//controllo della connessione in fase di avvio dell'app
if(isConnected(this))
{
//aggiungere qui eventuale codice da eseguire se il dispositivo è connesso ad internet
}
else
{
//aggiungere qui eventuale codice da eseguire se il dispositivo NON è connesso ad internet
Toast.makeText(this, "Non connesso ad internet", Toast.LENGTH_LONG).show()
}
//fine del controllo
}
//funzione che verifica lo stato della connessione internet
private fun isConnected(context: Context): Boolean
{
val connectivityManager = context.getSystemService(Context.CONNECTIVITY_SERVICE) as ConnectivityManager
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
////per versioni Android uguali o superiori ad Android M (Android 6.0 - API 23)
val nw = connectivityManager.activeNetwork ?: return false
val actNw = connectivityManager.getNetworkCapabilities(nw) ?: return false
return when {
actNw.hasTransport(NetworkCapabilities.TRANSPORT_WIFI) -> true
actNw.hasTransport(NetworkCapabilities.TRANSPORT_CELLULAR) -> true
//per altri dispositivi che sono in grado di connettersi con Ethernet
actNw.hasTransport(NetworkCapabilities.TRANSPORT_ETHERNET) -> true
//per controllare la connessione Internet tramite Bluetooth
actNw.hasTransport(NetworkCapabilities.TRANSPORT_BLUETOOTH) -> true
else -> false
}
}
else //per versioni Android inferiori ad Android M (Android 6.0 - API 23)
{
return connectivityManager.activeNetworkInfo?.isConnected ?: false
}
}
//fine della funzione che verifica lo stato della connessione internet
}



Download Project
Download file APK


Commenti

Post popolari in questo blog

Android Studio - Impostare lingua app

In questo articolo vedremo come poter selezionare la lingua all'interno della nostra app. Nel precedente articolo in cui si parlava del file string.xml , la lingua dell'app veniva selezionata automaticamente in base alle impostazioni del dispositivo, mentre qui vedremo come poter selezionare a proprio piacimento la lingua che dovrà avere la nostra app indipendentemente dall'impostazione del dispositivo. Per prima cosa creare il layout Ecco un esempio do come può essere il file activity_main.xml Ora creare le stringhe di testo all'interno del file string.xml Ora creare la traduzione del file string.xml nelle varie lingua come descritto in questo articolo Il risultato sarà una serie di file string.xml delle varie lingue impostate. Ora queste di seguito sono tre funzioni che servono per: selezione della lingua salvataggio della selezione nelle preferenze dell'app caricamento della lingua quando si avvia l'app Ecco come si presenta il file Main...

Android Studio - Rinominare il progetto

Rinominare il progetto Android Studio ATTENZIONE!: non eseguire questa procedura se l'app è stata pubblicata su Google Play Store Quando si vuole cambiare nome al progetto: nome cartella in cui è contenuto il progetto package name bisogna eseguire questi passaggi: Andare nella cartella dove è contenuto il progetto Creare una copia del progetto in questione Rinominare la cartella copiata con il nome dell'app (non usare spazi tra le parole) Ora è necessario dire ad Android Studio il nome del nuovo progetto  Aprire Android Studio Aprire il progetto creato in precedenza Una volta caricato il progetto cliccare Build Cliccare Clean Project Attendere che venga eseguito il processo di "pulitura" Cliccare ancora su Build Cliccare su Rebuild Project Attendere che venga ricostruito il progetto Ora aprire la cartella app fino a visualizzare la cartella java Cliccare sull'ingranaggio  Deselezionare la voce Compact Middle Packa...

Arduino - Lettura tensione potenziometro e display LCD

Leggere il valore di un poteziometro (parte 2) Oggi vedremo come leggere il valore in tensione di un potenziometro collegato al pin Analogico A0 di Arduino.