在之前我们之前操作控件通过id(findviewbyid)现在我们使用一种新的方法:viewBinding
第一步:添加依赖
viewBinding{
enabled=true;
}
第二步:使用
activityMainBinding=ActivityMainBinding.inflate(getLayoutInflater());//初始化 setContentView(activityMainBinding.getRoot()); activityMainBinding.tx1.setText("hello crq");
webView
1:加入webview布局
2:使用(因为我们加载网络资源所以第一步需要加权限(这个可以自己加))
我们换一个网址:会发现他是自动调用的浏览器来加载的这个资源,我们需要他自己加载
解决办法
activityMainBinding.w1.setWebViewClient(new WebViewClient(){
public boolean shouldOverUrlLoading(WebView webview,String url){
webview.loadUrl(url);
return true;
}
});
加载成功我们又会发现不能和屏幕自适应大小
解决办法:
//自适应大小
WebSettings webSettings = activityMainBinding.w1.getSettings();//这里的w1是我的id
//如果访问的页面中要与Javascript交互,则webview必须设置支持Javascript
webSettings.setJavaScriptEnabled(true);
//设置自适应屏幕,两者合用
webSettings.setUseWideViewPort(true); //将图片调整到适合webview的大小
webSettings.setLoadWithOverviewMode(true); // 缩放至屏幕的大小
//自适应屏幕
activityMainBinding.w1.getSettings().setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);
webSettings.setLoadWithOverviewMode(true); // 缩放至屏幕的大小
//缩放操作
webSettings.setSupportZoom(true); //支持缩放,默认为true。是下面那个的前提。
webSettings.setBuiltInZoomControls(true); //设置内置的缩放控件。若为false,则该WebView不可缩放
webSettings.setDisplayZoomControls(false); //隐藏原生的缩放控件
//其他细节操作
webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); //关闭webview中缓存
webSettings.setAllowFileAccess(true); //设置可以访问文件
webSettings.setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口
webSettings.setLoadsImagesAutomatically(true); //支持自动加载图片
webSettings.setDefaultTextEncodingName("utf-8");//设置编码格式
//优先使用缓存
webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);
//缓存模式如下:
//LOAD_CACHE_ONLY: 不使用网络,只读取本地缓存数据
//LOAD_DEFAULT: (默认)根据cache-control决定是否从网络上取数据。
//LOAD_NO_CACHE: 不使用缓存,只从网络获取数据.
//LOAD_CACHE_ELSE_NETWORK,只要本地有,无论是否过期,或者no-cache,都使用缓存中的数据
//不使用缓存
webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);
最后效果: