Android webView字体突然变小的原因及解决

 更新时间:2021年03月23日 08:48:30   作者:程序员徐公  
这篇文章主要介绍了Android webView字体突然变小的原因及解决,帮助大家更好的理解和学习使用Android开发,感兴趣的朋友可以了解下

背景

最近,端内在做 webView 统一的时候,个性签名中的 WebView 替换为 CustomWebView 之后,发现字体突然变小。

一开始不知道是什么原因,通过二分法查找最近的提交,排查之后,发现是 SignatureWebView 的继承关系从 WebView 修改为 CustomWebView。revert 之后就正常了。

于是,我问自己,为什么会这样呢?

原因分析

我们知道,WebViewSetting 里面是可以修改 WebView 的一些默认设置的。

阅读官方文档,发现 setLoadWithOverviewMode,setUseWideViewPort 这两个方法看起来跟 WebView 缩放相关。

于是尝试把 setLoadWithOverviewMode 改为 false,很神奇,竟然正常了。

setLoadWithOverviewMode

这个方法的作用,简单来说,就是是否根据屏幕宽度自适应

Sets whether the WebView loads pages in overview mode, that is, zooms out the content to fit on screen by width. This setting is taken into account when the content width is greater than the width of the WebView control, for example, when getUseWideViewPort() is enabled. The default is false.

developer.android.com/reference/a…

这个问题解决之后,我心中又有这样的疑问,为什么别的地方没有问题,只有个性签名这里的 WebView 有问题。

带着这个疑问,我再次去浏览代码,发现个性签名里面 Webview 加载的网页,是自己拼接的 html。debug 之后,发现网页代码大概是这样的

<span style="word-wrap:break-word;font-family:system-ui;font-size:16px;color:#888888;">Https://www.baidu.com</span>

可以看到里面字体的单位是 px,跟 Android 的 dp px 有点像,是不是没作屏幕适配?

搜索发现 Web 网页的代码适配单位是 rem,有点类似于 dp。

Web 网页在适配分辨率的时候,通常会设置 viewport 属性

于是我尝试在代码里面加了这样的代码,发现 SignatureWebView 显示个性签名又正常了。

parsedHtml += "<meta name=\"viewport\" content=\"width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no,viewport-fit=cover\">";

Web 网页字体的适配规则,这里就不班门弄斧了,有兴趣的可以自行搜索。

端内其他地方排查

我们知道,加载自定义 html,通常需要调用 loadDataWithBaseURL 方法,查看端内调用的地方,发现其他都是正常的。只有这个奇葩 SignatureWebView ,自己拼接的 html 没有加 viewport 属性,进行适配

总结

  1. 如果 html 是自己拼接的,并且像素是 px,不要设置 WebViewSetting 的 setLoadWithOverviewMode ,setUseWideViewPort(默认属性是 false),否则字体可能显示不正常,偏大或者偏小
  2. 如果 html 是自己拼接的,并且像素是 px,当我们设置 WebViewSetting 的 setLoadWithOverviewMode ,setUseWideViewPort 为 true(根据屏幕自适应),那么我们需要设置 html 的 viewport 规则,否则可能显示不正常
  3. html 如果是自己拼接的,需要注意适配规则,像个人签名这种,用 webView 承载自己拼接的 html ,防止踩坑

WebView 字体常见的其他坑

手机设置字体大小导致h5页面在webview中变形

出现这个问题的原因是

  1. 默认浏览器中的内容是不受系统字体大小设置控制的,至少我遇到的几台手机都是这样的情况。
  2. 某些机型 WebView 字体的大小是受手机系统字体大小控制的

这个通常有两种解决方案。

Web js 网页解决方案

  1. 一般,我们动态计算好html的font-size之后,我们就啥都不干了,就走了。
  2. 但是,我们现在知道了,我们设置的大小不一定是真实的大小,所以,我们需要在设置完字体大小之后,再去重新获取一下html的font-size,看看实际的这个值,和我们设置的是不是一样。
  3. 如果不一样,就要根据比例再设置一次。
function htmlFontSize(){
 var h = Math.max(document.documentElement.clientHeight, window.innerHeight || 0);
 var w = Math.max(document.documentElement.clientWidth, window.innerWidth || 0);
 var width = w > h ? h : w;
 width = width > 720 ? 720 : width
 var fz = ~~(width*100000/36)/10000
 document.getElementsByTagName("html")[0].style.cssText = 'font-size: ' + fz +"px";
 var realfz = ~~(+window.getComputedStyle(document.getElementsByTagName("html")[0]).fontSize.replace('px','')*10000)/10000
 if (fz !== realfz) {
  document.getElementsByTagName("html")[0].style.cssText = 'font-size: ' + fz * (fz / realfz) +"px";
 }
}

客户端 WebView 禁止缩放

Android WebView 是可以通过 WebSettings 禁止网页字体缩放的,可以通过 setTextZoom 方法解决

webview.getSettings().setTextZoom(100)

小结

这篇文章主要是记录 bug 的一个解决过程,技术含量不高,但是有一定的参考价值。尤其是 bug 的解决思路。

  1. 线上突然出现问题,一直找不出问题,尝试一下二分法,逐步缩小范围。
  2. 有时候,我们找到解决方案,却不一定知道原因是什么,这时候,可以多问一下自己,背后的原因是什么?在排查的过程中,我们会逐渐培养自己的一套问题解决思路,听起来很虚,但是确实存在的。
  3. 知道原因之后,我们可以继续再进一步排查一下,项目中其他模块是不是也存在这样的问题。
  4. 以后要怎么规避之类问题?写个 wiki 或者博客记录一下

以上就是Android webView字体突然变小的原因及解决的详细内容,更多关于Android webView字体突然变小的资料请关注脚本之家其它相关文章!

相关文章

  • 使用Timer实现网页匀速加载的进度条样式

    使用Timer实现网页匀速加载的进度条样式

    这篇文章主要介绍了使用Timer实现网页匀速加载的进度条样式,在使用WebView加载网页时有时候网速等原因加载比较慢时,影响用户的体验度,今天小编给大家分享使用timer实现网页匀速加载的进度条样式,需要的的朋友参考下吧
    2017-01-01
  • Android实现微信首页左右滑动切换效果

    Android实现微信首页左右滑动切换效果

    这篇文章主要介绍了Android实现微信首页左右滑动切换效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • Android自动测试工具Monkey

    Android自动测试工具Monkey

    Monkey是Android中的一个命令行工具,可以运行在模拟器里或实际设备中。它向系统发送伪随机的用户事件流(如按键输入、触摸屏输入、手势输入等),实现对正在开发的应用程序进行压力测试。Monkey测试是一种为了测试软件的稳定性、健壮性的快速有效的方法
    2016-01-01
  • Android开发之资源文件用法实例总结

    Android开发之资源文件用法实例总结

    这篇文章主要介绍了Android开发之资源文件用法,结合实例形式总结分析了Android开发过程中针对资源文件的常见操作技巧,需要的朋友可以参考下
    2016-02-02
  • Android获取、更改包名的小技巧分享(超实用)

    Android获取、更改包名的小技巧分享(超实用)

    这篇文章主要给大家分享介绍了关于利用Android更改包名的一个小技巧,通过这个方法大家可以很方便的修改包名,再也不用为频繁修改包名而感到头疼,文中还给大家分享利一个android获取手机所有应用包名的方法,下面随着小编来一起学习学习吧。
    2017-12-12
  • Android采用消息推送实现类似微信视频接听

    Android采用消息推送实现类似微信视频接听

    这篇文章主要为大家详细介绍了Android采用消息推送实现类似微信视频接听,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11
  • Android采用File形式保存与读取数据的方法

    Android采用File形式保存与读取数据的方法

    这篇文章主要介绍了Android采用File形式保存与读取数据的方法,涉及Android文件流操作的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-06-06
  • Android TextWatcher监控EditText中的输入内容并限制其个数

    Android TextWatcher监控EditText中的输入内容并限制其个数

    本篇文章主要介绍了Android TextWatcher监控EditText中的输入内容并限制其个数,我们可以通过TextWatcher去观察输入框中输入的内容,有兴趣的可以了解一下。
    2017-04-04
  • Android开发中常见问题

    Android开发中常见问题

    这篇文章主要为大家详细介绍了Android开发中常见问题,主要涉及了七个问题,希望能帮助到大家,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • Android实现树形层级ListView

    Android实现树形层级ListView

    这篇文章主要介绍了Android实现树形层级ListView的相关资料,需要的朋友可以参考下
    2016-02-02

最新评论