Android 에서 WebView 의 간단 한 용법
WebView 컨트롤 에 대한 간단 한 활용 을 쓰 려 고 했 는데 시간 이 별로 없 었 습 니 다.이번에 도 시간 을 내 서 썼 습 니 다.그 안에 있 는 기초 지식 은 시간 이 있 으 면 다시 설명 을 업데이트 하고 오늘 은 프로젝트 를 간단하게 소개 하 겠 습 니 다.너무 많은 내용 은 제 소스 코드 를 볼 수 있 고 모두 github 에 전 달 했 습 니 다.
다음은 프로젝트 의 효과 그림 입 니 다:
 
  
  
  
 응용 프로그램 은 MVP 디자인 모델 을 사용 합 니 다.이런 모델 에 대해 잘 모 르 는 것 은 먼저 자체 구 글 을 사용 할 수 있 습 니 다.그렇지 않 으 면 프로젝트 가 어 지 럽 게 보일 것 입 니 다.제 코드 는 모두 간결 하지만.
MVP 에 대해 하나의 사고방식 을 가지 고 소스 코드 를 볼 수 있다.그것 이 바로 activity(또는 다른 구성 요소)가 xx Presenter 를 통 해 데 이 터 를 가 져 오고 데 이 터 를 받 아 xx Presenter 에서 xx IView(이것 은 인터페이스)를 이용 하여 데 이 터 를 업데이트 하 는 것 이다.그러면 activity(또는 다른 구성 요소)가 xx IView 라 는 연결 구 를 계승 하면 UI 를 업데이트 할 수 있다.
사실 WebView 는 간단 한 것 만 사용 하고 이 글 을 깊이 응용 하면 업 데 이 트 됩 니 다!
그 중:
    //  WebView        
    webView.setScrollBarStyle(WebView.SCROLLBARS_OUTSIDE_OVERLAY); 
    webView.setHorizontalScrollBarEnabled(false); 
    webView.getSettings().setSupportZoom(true); 
    //  WebView       
    webView.getSettings().setBuiltInZoomControls(true); 
    webView.setInitialScale(70); 
    webView.setHorizontalScrollbarOverlay(true); 
    //WebView    ,      ,      ,           
    //webView.getSettings().setUseWideViewPort(true); 
    //        
    webView.getSettings().setRenderPriority(RenderPriority.HIGH);
    //  JS  
    webView.getSettings().setJavaScriptEnabled(true);
    //              
    //webView.getSettings().setBlockNetworkImage(true); 
    // WebView     HTML        
    //webView.loadDataWithBaseURL("fake://not/needed", <p>zzz</p>, "text/html", "utf-8", "");
    //          ,           ,      : 
 mWebView.addJavascriptInterface(new WebAppInterface(customView.getContext()),"Android");
 public class WebAppInterface {
    Context mContext;
    /** Instantiate the interface and set the context */
    WebAppInterface(Context c) {
      mContext = c;
    }
    /** Show a toast from the web page */
    @JavascriptInterface
    public void showToast(String toast) {
      //      webview   html                
    }
html 페이지 에 html 탭 을 기록 합 니 다."
"
프로젝트 소스 코드
                
  public static String buildHtmlWithCss(String html, String[] cssUrls, boolean isNightMode) {
    StringBuilder result = new StringBuilder();
    for (String cssUrl : cssUrls) {
      result.append(String.format(CSS_LINK_PATTERN, cssUrl));
    }
    if (isNightMode) {
      result.append(NIGHT_DIV_TAG_START);
    }
    result.append(html.replace(DIV_IMAGE_PLACE_HOLDER, DIV_IMAGE_PLACE_HOLDER_IGNORED));
    if (isNightMode) {
      result.append(NIGHT_DIV_TAG_END);
    }
    return result.toString();
  }
프로젝트 소스 코드
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Bitrise에서 배포 어플리케이션 설정 테스트하기이 글은 Bitrise 광고 달력의 23일째 글입니다. 자체 또는 당사 등에서 Bitrise 구축 서비스를 사용합니다. 그나저나 며칠 전 Bitrise User Group Meetup #3에서 아래 슬라이드를 발표했...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.