Androidの拡張されたWebViewコンポーネントは、箱から出して意図したとおりに機能するように機能します
ルートbuild.gradleでグラードルリポジトリを宣言します
allprojects {
repositories {
maven { url " https://jitpack.io " }
}
}アプリモジュールのbuild.gradleのグラードル依存関係を宣言します
dependencies {
implementation ' com.github.delight-im:Android-AdvancedWebView:v3.2.1 '
}< uses-permission android : name = " android.permission.INTERNET " />< im .delight.android.webview.AdvancedWebView
android : id = " @+id/webview "
android : layout_width = " match_parent "
android : layout_height = " match_parent " /> public class MyActivity extends Activity implements AdvancedWebView . Listener {
private AdvancedWebView mWebView ;
@ Override
protected void onCreate ( Bundle savedInstanceState ) {
super . onCreate ( savedInstanceState );
setContentView ( R . layout . activity_my );
mWebView = ( AdvancedWebView ) findViewById ( R . id . webview );
mWebView . setListener ( this , this );
mWebView . setMixedContentAllowed ( false );
mWebView . loadUrl ( "http://www.example.org/" );
// ...
}
@ SuppressLint ( "NewApi" )
@ Override
protected void onResume () {
super . onResume ();
mWebView . onResume ();
// ...
}
@ SuppressLint ( "NewApi" )
@ Override
protected void onPause () {
mWebView . onPause ();
// ...
super . onPause ();
}
@ Override
protected void onDestroy () {
mWebView . onDestroy ();
// ...
super . onDestroy ();
}
@ Override
protected void onActivityResult ( int requestCode , int resultCode , Intent intent ) {
super . onActivityResult ( requestCode , resultCode , intent );
mWebView . onActivityResult ( requestCode , resultCode , intent );
// ...
}
@ Override
public void onBackPressed () {
if (! mWebView . onBackPressed ()) { return ; }
// ...
super . onBackPressed ();
}
@ Override
public void onPageStarted ( String url , Bitmap favicon ) { }
@ Override
public void onPageFinished ( String url ) { }
@ Override
public void onPageError ( int errorCode , String description , String failingUrl ) { }
@ Override
public void onDownloadRequested ( String url , String suggestedFilename , String mimeType , long contentLength , String contentDisposition , String userAgent ) { }
@ Override
public void onExternalPageRequest ( String url ) { }
}android.app.Fragment )注:サポートライブラリ( android.support.v4.app.Fragment )のFragmentクラスを使用している場合は、これではなく次のセクション(以下を参照)を参照してください。
public class MyFragment extends Fragment implements AdvancedWebView . Listener {
private AdvancedWebView mWebView ;
public MyFragment () { }
@ Override
public View onCreateView ( LayoutInflater inflater , ViewGroup container , Bundle savedInstanceState ) {
View rootView = inflater . inflate ( R . layout . fragment_my , container , false );
mWebView = ( AdvancedWebView ) rootView . findViewById ( R . id . webview );
mWebView . setListener ( this , this );
mWebView . setMixedContentAllowed ( false );
mWebView . loadUrl ( "http://www.example.org/" );
// ...
return rootView ;
}
@ SuppressLint ( "NewApi" )
@ Override
public void onResume () {
super . onResume ();
mWebView . onResume ();
// ...
}
@ SuppressLint ( "NewApi" )
@ Override
public void onPause () {
mWebView . onPause ();
// ...
super . onPause ();
}
@ Override
public void onDestroy () {
mWebView . onDestroy ();
// ...
super . onDestroy ();
}
@ Override
public void onActivityResult ( int requestCode , int resultCode , Intent intent ) {
super . onActivityResult ( requestCode , resultCode , intent );
mWebView . onActivityResult ( requestCode , resultCode , intent );
// ...
}
@ Override
public void onPageStarted ( String url , Bitmap favicon ) { }
@ Override
public void onPageFinished ( String url ) { }
@ Override
public void onPageError ( int errorCode , String description , String failingUrl ) { }
@ Override
public void onDownloadRequested ( String url , String suggestedFilename , String mimeType , long contentLength , String contentDisposition , String userAgent ) { }
@ Override
public void onExternalPageRequest ( String url ) { }
}android.support.v4.app.Fragment )上記のように、通常のFragment使用にコードを使用します
変化
mWebView . setListener ( this , this );に
mWebView . setListener ( getActivity (), this );結果を適切なFragmentインスタンスにFragmentActivityから転送するために、次のコードを親FragmentActivityに追加します
public class MyActivity extends FragmentActivity implements AdvancedWebView . Listener {
@ Override
public void onActivityResult ( int requestCode , int resultCode , Intent intent ) {
super . onActivityResult ( requestCode , resultCode , intent );
if ( mFragment != null ) {
mFragment . onActivityResult ( requestCode , resultCode , intent );
}
}
} -keep class * extends android.webkit.WebChromeClient { *; }
-dontwarn im.delight.android.webview.**
httpsではなく、プレーンhttpを介してサイトまたは単一のリソースを提供したい場合は、Android 8.1(APIレベル27)以前をターゲットにしている場合、通常は何もすることはありません。ただし、Android 9(APIレベル28)以降では、デフォルトではClearTextサポートが無効になります。 Android: AndroidManifest.xmlの<application>要素でandroid:usesCleartextTraffic="true"を設定するか、カスタムネットワークセキュリティ構成を提供する必要がある場合があります。
最高のパフォーマンスとセキュリティのために最適化されています
機能は、Androidバージョン全体でパッチされています
ファイルのアップロードは自動的に処理されます( AdvancedWebView.isFileUploadAvailable()で可用性を確認します)
multiple属性)を介した複数のファイルアップロードがサポートされています。ファイルを選択するために使用されるアプリケーション(つまり、通常はギャラリーまたはファイルマネージャーアプリ)は、複数のファイルを選択するためのコントロールを提供する必要があります。JavaScriptとWebstorageはデフォルトで有効になっています
最も広く話されている25の言語のローカライズが含まれています
ページが開始/終了したときにコールバックを受信したり、エラーが発生したりします
@ Override
public void onPageStarted ( String url , Bitmap favicon ) {
// a new page started loading
}
@ Override
public void onPageFinished ( String url ) {
// the new page finished loading
}
@ Override
public void onPageError ( int errorCode , String description , String failingUrl ) {
// the new page failed to load
}ダウンロードは自動的に処理され、聴くことができます
@ Override
public void onDownloadRequested ( String url , String suggestedFilename , String mimeType , long contentLength , String contentDisposition , String userAgent ) {
// some file is available for download
// either handle the download yourself or use the code below
if ( AdvancedWebView . handleDownload ( this , url , suggestedFilename )) {
// download successfully handled
}
else {
// download couldn't be handled because user has disabled download manager app on the device
// TODO show some notice to the user
}
} Geolocation Supportを有効にします(ニーズ<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> )
mWebView . setGeolocationEnabled ( true );Webブラウザーの実装によって送信されたものに加えて、カスタムHTTPヘッダーを追加します
mWebView . addHttpHeader ( "X-Requested-With" , "My wonderful app" );許可されたホスト名のカスタムセットを定義し、他のすべてのホスト名のコールバックを受信します
mWebView . addPermittedHostname ( "example.org" );そして
@ Override
public void onExternalPageRequest ( String url ) {
// the user tried to open a page from a non-permitted hostname
}HTMLページのキャッシュを防ぎます
boolean preventCaching = true ;
mWebView . loadUrl ( "http://www.example.org/" , preventCaching );デバイスにインストールされている代替ブラウザを確認してください
if ( AdvancedWebView . Browsers . hasAlternative ( this )) {
AdvancedWebView . Browsers . openUrl ( this , "http://www.example.org/" );
}Cookieを無効にします
// disable third-party cookies only
mWebView . setThirdPartyCookiesEnabled ( false );
// or disable cookies in general
mWebView . setCookiesEnabled ( false );許可または許可(パッシブとアクティブの両方)混合コンテンツ(HTTPSサイト内にロードされているHTTPコンテンツ)
mWebView . setMixedContentAllowed ( true );
// or
mWebView . setMixedContentAllowed ( false );モバイルモードとデスクトップモードを切り替えます
mWebView . setDesktopMode ( true );
// or
// mWebView.setDesktopMode(false); 「Assets」からHTMLファイルをロードする(例: app/src/main/assets/html/index.html )
mWebView . loadUrl ( "file:///android_asset/html/index.html" );SDカードからHTMLファイルをロードします
// <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
if ( Environment . getExternalStorageState (). equals ( Environment . MEDIA_MOUNTED )) {
mWebView . getSettings (). setAllowFileAccess ( true );
mWebView . loadUrl ( "file:///sdcard/Android/data/com.my.app/my_folder/index.html" );
}HTMLソーステキストと表示ページとして表示します
myWebView . loadHtml ( "<html>...</html>" );
// or
final String myBaseUrl = "http://www.example.com/" ;
myWebView . loadHtml ( "<html>...</html>" , myBaseUrl );マルチウィンドウサポートを有効にします
myWebView . getSettings (). setSupportMultipleWindows ( true );
// myWebView.getSettings().setJavaScriptEnabled(true);
// myWebView.getSettings().setJavaScriptCanOpenWindowsAutomatically(true);
myWebView . setWebChromeClient ( new WebChromeClient () {
@ Override
public boolean onCreateWindow ( WebView view , boolean isDialog , boolean isUserGesture , Message resultMsg ) {
AdvancedWebView newWebView = new AdvancedWebView ( MyNewActivity . this );
// myParentLayout.addView(newWebView, LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);
WebView . WebViewTransport transport = ( WebView . WebViewTransport ) resultMsg . obj ;
transport . setWebView ( newWebView );
resultMsg . sendToTarget ();
return true ;
}
}すべての貢献は大歓迎です!貢献したい場合は、最初に問題を作成して、機能、問題、または質問を議論できるようにしてください。
このプロジェクトは、MITライセンスの条件に基づいてライセンスされています。