关于实现一个图片选择库踩过的坑

2022-07-02  本文已影响0人  motosheep

图库地址:代码

目前,该图片选择库,仍然在更新迭代中。
本文是专门记录该图库在开发过程中遇到的坑。

一、FileProvider定义问题

由于当初的FileProvider定义不当,会导致编译时候,报AndroidManifest合并报错。
先放出原来有可能引起报错的代码,如下图:

<provider
            android:name="androidx.core.content.FileProvider"
            android:authorities="${applicationId}.fileProvider"
            android:exported="false"
            android:grantUriPermissions="true">
            <meta-data
                android:name="android.support.FILE_PROVIDER_PATHS"
                android:resource="@xml/provider_paths" />
                android:resource="@xml/lib_pic_provider_paths" />
 </provider>

由于“name”是“androidx.core.content.FileProvider”,所以就有可能存在重复导致合并过程中报错。修改如下:

        <provider
            android:name="com.north.light.libpicselect.fileprovider.LibPicFileProvider"
            android:authorities="${applicationId}.fileProvider"
            android:exported="false"
            android:grantUriPermissions="true">
            <meta-data
                android:name="android.support.FILE_PROVIDER_PATHS"
                android:resource="@xml/lib_pic_provider_paths" />
        </provider>

name换成了具体定义的一个类即可。

注意:使用的时候 FileProvider.getUriForFile 需要和 authorities保持一致。

二、图片错乱

使用RecyclerView和Glide配合加载图片,就有可能出现这种情况。再者,配合RecyclerView滑动时不加载,停止时才加载的监听。这个bug会让开发者一度陷入自我怀疑。
首先,拆分问题:
(一)不用RecyclerView滑动监听优化的情况下,如何解决?没错,只需要使用tag就可以实现了。具体就是在value目录下,先自定义一个id,然后在adapter的bind holder过程中,通过settag,gettag判断,符合才加载。这样就能解决大部分问题了。
(二)配合了RecyclerView滑动监听优化的情况下,还是会出现某个位置的图片错乱。我遇到的情况是。第一个位置显示了本地“相机"图片。然后配合了RecyclerView滑动监听优化下,”相机“图片会出现不了。原理其实很简单:
(1)ViewHolder是复用的,有可能是上一次的图片。
(2)RecyclerView停止时才加载,但是这个时候,bindholder方法已经走完,存在时间差。
解决方法--直接用一个新的控件,用于显示”相机“图标布局。

三、图片的加载

对于图片加载,本图库完全交由开发者外部处理。图库中不含任何图片加载三方库。
为什么这样设计?原因如下:
(1)没必要引入不需要的库,就算引入,也要交由开发者选择
(2)避免版本不同导致的兼容性问题
(3)减少库体积

that's all ------------------------------------------------------------------------------------------------

上一篇 下一篇

猜你喜欢

热点阅读