=================================
=================================
=================================
출처: https://m.blog.naver.com/PostView.nhn?blogId=horajjan&logNo=220313786494&proxyReferer=https%3A%2F%2Fwww.google.co.kr%2F
'하이브리드 앱을 구현하는 기술, 12장'을 인용하였다
우선, 안드로이드에서 WebView를 사용하여 화면에 표시하는 기본 코드를 소개한다
public class JSInterfaceSandbox extends Activity { WebView webView = null; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); webView = new WebView(this); setContentView(webView); // assets 디렉토리의 index.html을 읽어온다 webView.loadUrl("file:///android_asset/index.html"); } } |
WebView의 기본적인 설정은 WebSettings를 이용한다
WebSettings 설정하기
webView = new WebView(this); android.webkit.WebSettings settings = webView.getSettings(); // 자바스크립트를 유효하게 한다 settings.setJavascriptEnabled(true); // 뷰포트를 이용할 수 있게 한다 settings.setUseWideViewPort(true); // 컨텐트 프로바이더(CP)를 이용할 때는 true를 설정한다 // WebView도 컨텐트 프로바이더가 제공하는 컨텐츠를 읽어올 수 있다 settings.setAllowContentAccess(false); // file://URL이면 어느 오리진에 대해서도 Ajax로 요청을 보낼 수 있다 // API 레벨 16부터 이용할 수 있다 try { settings.setAllowUniversalAccessFromFileURLs(true); } catch(Exception e) { // 아무것도 하지 않는다 } // WebView에는 줌 기능이 내장되어 있다 settings.setBuiltInZoomControls(false); // WebSQL 데이터베이스를 유효하게 한다 settings.setDatabaseEnabled(true); String databasePath = getApplicationContext().getDir("websqldatabase", Context.MODE_PRIVATE).getPath(); settings.setDatabasePath(databasePath); // localStorage, sessionStorage를 유효화한다 settings.setDomStorageEnabled(true); // window.open 메서드를 이용할 때의 동작을 설정할 수 있게 한다 settings.setJavaScriptCanOpenWindowsAutomatically(true); settings.setSupportMultipleWindows(true); // 사용자의 조작이 없어도 미디어를 재생할 수 있는지 설정한다 settings.setMediaPlaybackRequiresUserGesture(false); // 폼의 입력값과 패스워드의 로그를 보존하지 않도록 한다 settings.setSaveFormData(false); settings.setSavePassword(false); |
WebSettings 클래스에서는 몇 가지 설정 항목이 더 있다. 자세한 내용은 다음 문서를 참고하기 바란다
WebView 오브젝트에 메서드를 오버라이드한 WebViewClient 오브젝트와 WebChromeClient 오브젝트를 설정함으로서 WebView의 동작을 확장할 수 있다
WebViewClient 오브젝트 설정하기
webView.setWebViewClient(new WebViewClient() { // 페이지 읽기가 시작되었을 때의 동작을 설정한다 @Ovrride public void onPageStarted(WebView v, String url, Bitmap b) { // ... } // 페이지 읽기가 끝났을 때의 동작을 설정한다 @Ovrride public void onPageFinished(WebView v, String url) { // ... } // a 태그와 location.href가 변했을 때의 동작을 지정한다 @Ovrride public boolean shouldOverrideUrlLoading(WebView v, String url) { // ... } // WebView가 던지는 요청을 어떻게 다룰지 지정한다 @Ovrride public WebResourceResponse shouldInterceptRequest(WebView v, String url) { // ... } }); |
onPageStarted, onPageFinished, shouldOverrideUrlLoading 메서드는 WebView가 페이지를 읽을 때 호출된다. iframe 요소와 object 요소 안에서 페이지를 읽을 때에도 호출된다
자세한 것은 다음 문서를 참조하기 바란다
WebViewClient 클래스와 마찬가지로 WebChromeClient 클래스를 설정함으로써 WebView를 관리할 수 있다
webView.setWebChromeClient(new WebChromeClient() { @Ovrride public void onJSAlert(WebView v, String url, String message, JsResult result) { return super.onJsAlert(v, url, message, result); } @Ovrride public void onJSPrompt(WebView v, String url, String message, String defaultValue, JsPromptResult result) { return super.onJsPrompt(v, url, message, defaultValue, result); } @Ovrride public void onJSConfirm(WebView v, String url, String message, JsResult result) { return super.onJsConfirm(v, url, message, result); } @Ovrride public void onConsoleMessage(ConsoleMessage cm) { String line = cm.message() + " " + cm.soureId() + ":" + cm.lineNumber(); ConsoleMessage.MessageLevel level = cm.messageLevel(); if (level == ConsoleMessage.MessageLevel.TIP) Log.v("webview", line); else if (level == ConsoleMessage.MessageLevel.DEBUG) Log.d("webview", line); else if (level == ConsoleMessage.MessageLevel.LOG) Log.i("webview", line); else if (level == ConsoleMessage.MessageLevel.WARNING) Log.w("webview", line); else if (level == ConsoleMessage.MessageLevel.ERROR) Log.e("webview", line); return true; } }); |
안드로이드 Activity 생명주기 변화에 따라서 WebView의 상태를 변화시키는 코드는 다음과 같다
Activity 생애주기에 WebView 이용하기
public class JSInterfaceSandbox extends Activity { WebView webView = null; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); webView = new WebView(this); webView.getSettings().setJavascriptEnabled(true); if (savedInstanceState != null) webView.restoreState(savedInstanceState); else webView.loadUrl("file:///android_asset/index.html"); setContentView(webView); } @Override public void onResume(Bundle savedInstanceState) { // WebView 안의 자바스크립트 타이머를 복귀시킨다 webView.resumeTimers(); } @Override public void onPause(Bundle outState) { super.onPause(ontState); // WebView 안의 자바스크립트 타이머를 멈춘다 webView.pauseTimers(); } @Override public void onSaveInstanceState(Bundle outState) { super.onSaveInstanceState(ontState); // WebView 의 상태를 보존한다 webView.saveState(outState); } @Override public void onDestroy() { super.onSaveInstanceState(ontState); // WebView 를 폐기한다 webView.stopLoading(); webView.setWebViewClient(null); webView.setWebChromeClient(null); webView.destroy(); webView = null; super.onDestroy(); } } |
=================================
=================================
=================================
출처: http://superwony.tistory.com/17
안녕하세요 이번 포스팅은 하이브리드 앱에서 주로 사용되는 웹뷰 세팅 속성에 관한 내용입니다. 웹뷰는 버전 2.2 이상부터 지원되고 흔히 사용하는 네이버등이 웹뷰를 사용중인 하이브리드 앱입니다. |
웹뷰를 선언하는 방법은 아래 방법외에 다양한 방법으로 가능합니다.
wb_content=(WebView)findViewById(R.id.wb_content);
주로 사용되는 속성 및 기타 속성들 입니다.
(추후에 더 조사하여 추가하도록 하겠습니다.)
private void settingWebview(WebView webView){
webView.getSettings().setJavaScriptEnabled(true);
webView.getSettings().setJavaScriptCanOpenWindowsAutomatically(true);
webView.getSettings().setLoadsImagesAutomatically(true);
webView.getSettings().setUseWideViewPort(true);
webView.getSettings().setSupportZoom(false);
webView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);
webView.getSettings().setAppCacheEnabled(false);
webView.getSettings().setDomStorageEnabled(true);
webView.getSettings().setAllowFileAccess(true);
webView.setWebChromeClient(new WebChromeClient());
webView.getSettings().setUserAgentString("app");
}
setJavaScriptEnabled ( false )
웹뷰를 사용하면 네이티브 영역에서 코드로 처리 되는 것이 거의 없는 경우가 많습니다. 그래서 자바스크립트로 이루어져 있는 기능들을 사용하기 위하여 해당 속성을 추가해야합니다. |
setJavaScriptCanOpenWindowsAutomatically ( false )
필요에 의해 팝업창을 띄울 경우가 있는데, 해당 속성을 추가해야 window.open() 이 제대로 작동합니다. |
setLoadsImagesAutomatically ( true )
웹뷰가 앱에 등록되어 있는 이미지 리소스를 자동으로 로드하도록 설정하는 속성입니다. |
setUseWideViewPort ( false )
웹뷰가 wide viewport를 사용하도록 설정하는 속성입니다. 그래서 html 컨텐츠가 웹뷰에 맞게 나타나도록 합니다. |
setSupportZoom ( true )
확대 축소 기능을 사용할 수 있도록 설정하는 속성입니다. |
setCacheMode
웹뷰의 캐시 모드를 설정하는 속성으로써 5가지 모드가 존재합니다. LOAD_CACHE_ELSE_NETWORK 기간이 만료돼 캐시를 사용할 수 없을 경우 네트워크를 사용합니다. LOAD_CACHE_ONLY 네트워크를 사용하지 않고 캐시를 불러옵니다. LOAD_DEFAULT 기본적인 모드로 캐시를 사용하고 만료된 경우 네트워크를 사용해 로드합니다. LOAD_NORMAL 기본적인 모드로 캐시를 사용합니다. LOAD_NO_CACHE 캐시모드를 사용하지 않고 네트워크를 통해서만 호출합니다. |
setDomStorageEnabled( false )
로컬 스토리지 사용 여부를 설정하는 속성으로 팝업창등을 '하루동안 보지 않기' 기능 사용에 필요합니다. |
setAppCacheEnabled ( false )
앱 내부 캐시 사용 여부 설정입니다. |
setAllowFileAccess
웹뷰 내에서 파일 액세스 활성화 여부 |
setUserAgentString
웹에서 해당 속성을 통해 앱에서 띄운 웹뷰로 인지 할 수 있도록 합니다. |
오타나 잘못된점 지적해주시면 확인 즉시 수정하도록 하겠습니다.
문의사항 및 이의사항에 대해서는 댓글이나 방명록으로 남겨주시면 확인후 신속하게 처리하겠습니다.
감사합니다.
출처: http://superwony.tistory.com/17 [개발자 키우기]
=================================
=================================
=================================
'스마트기기개발관련 > 안드로이드 개발' 카테고리의 다른 글
[android] 안드로이드 매니페스트 앱 권한 "WebView" 의Canvas, WebGL사용가능하게 , hardware acceleration(하드웨어 가속) 관련 (0) | 2018.04.11 |
---|---|
[android] 안드로이드 N, 안드로이드 7 이상 화면 사이즈 변경에 따른 대응 방법 관련 (0) | 2018.04.03 |
[android] 안드로이드 Assets 폴더 내에 html을 넣고 리소스,코드들 css, img, js 등등 를 상대경로로 사용하기 (3) | 2018.03.30 |
[android] 안드로이드 웹뷰로드, 로컬웹 로드 관련 (0) | 2018.03.30 |
[android] TextView 글자 크기 dp설정을 java코드로 설정하기 관련 (0) | 2018.03.14 |