前言:改个透明色也好意思发文章?难道是篇水文?😡 莫急,咱是个反标题党!
笔者当然知道给插件改个透明背景不值一提,毕竟Flutter目前的生态,轮子都经常得自己造,更别说改什么源码了。。。
但是通过这篇文章,你将会了解 如何魔改Flutter官方插件并自行维护,同时还能学到如何构建自己公司内部的插件库。
为何写这篇文章
承接以上前言,我之所以写这篇文章,是因为我改的是Flutter官方的插件webview_flutter。Flutter官方的插件,全部是在一个gitHub仓库上维护的,各个库之间又相互关联。【见下图】
所以改功能其实是其次,如何在这庞大的Flutter插件库里面单独修改你所需的插件,并且自行维护起来,这才是重点!!!我觉得是很有必要分享给大家的。
需求背景
这次改动的原因是Flutter webview的背景永远是白色,而我们的主题又是黑色的。这样H5嵌入的时候,需要H5的同事去设置黑色背景,同时网页还没加载出来时还会出现白色背景,体验极差。 如果能把webview的背景设置为透明,H5不需要设置背景色,从可维护性和体验都会有所提高,因此需求应运而生。
实现步骤
- 从github把plugin仓库clone下来,然后用Android studio单独打开webview文件夹,可以看到包含了三个Plugin。
2. 更改主插件依赖项
进入主插件webview目录,看到yaml依赖的还是pub上面的插件,所以我们改动其他目录下的源码,yaml根本就没有依赖到,是不会生效的。
flutter:
plugin:
platforms:
android:
default_pac