网上有很多图文混编的方案,无非两种

  1. webview
  2. SpannableString+ImageSpan

他们之间的优势比较什么的,网上很多,我也不再赘述,我这里直接选择第二种,因为简单,需求也只是可以插入图片.然后各种搜索如何实现,找到一篇博文

https://blog.csdn.net/ljzdyh/article/details/82497625

我的代码就是参考这篇文章来的,因为文章中有些地方使用的api已经被标记为弃用了,所以只好改一下,加点注释,试图让它更加通俗易懂.

阅读全文 »

网上查了一圈,没发现有人分享,一路吃坑吃过来,终于实现了自动刷新 token 并重发请求的拦截器。

然后就想着分享一下,也许分享出来可以帮助小伙伴快速实现自己的token刷新机制,关于Dio的拦截器,不过多介绍,直接前往 Dio 的文档,即可找到拦截器的介绍。我只说一下使用上需要注意的点,以及我写的代码。不多,也就70行。

拦截器文档传送门:Dio中文文档

阅读全文 »

一开始想过用子线程来实现,还好搜索了一下,发现 Android 自带了一个倒计时类,正好适合,这个类就是CountDownTimer,创建它需要提供两个参数,一个是总计时时间(单位是毫秒),一个是步长,也就是一次走多少毫秒.然后还需要实现它的两个接口.

  1. void onTick(long millisUntilFinished)
    当时间每走一次就会调用这个方法,参数是还剩下多少时间没走,在这里禁用按钮,然后显示还剩多少时间
  2. void onFinish()
    这个一看就知道是倒计时完成了,会回调它,可以在这里启用按钮

上示例代码

//倒计时60秒,这里不直接写60000,而用1000*60是因为后者看起来更直观,每走一步是1000毫秒也就是1秒
CountDownTimer timer = new CountDownTimer(1000 * 60, 1000) {
    @SuppressLint("DefaultLocale")
    @Override
    public void onTick(long millisUntilFinished) {
        button.setEnabled(false);
        button.setText(String.format("已发送(%d)",millisUntilFinished/1000));
    }

    @Override
    public void onFinish() {
        button.setEnabled(true);
        button.setText("重新获取");
    }
};
timer.start();

最后一定要记得 start()

在渲染订单列表的时候,用到了三层recyclerView嵌套,结果进入订单列表页,当最里层的数据一个屏幕装不下的时候,就会把外层的view挤出去.比如店铺名.后来查各种资料发现是焦点问题:
当新出现一个recyclerView的时候,这个recyclerView就会获得焦点,它的第一条数据就会出现在屏幕顶部,解决方案是:

<LinearLayout
   android:orientation="vertical"
   android:layout_width="match_parent"
   android:layout_height="wrap_content">

   <View
       android:focusable="true"
       android:focusableInTouchMode="true"
       android:layout_width="match_parent"
       android:layout_height="4dp"/>

   <android.support.v7.widget.RecyclerView
       android:id="@+id/rv_goods_cart"
       android:layout_width="match_parent"
       android:layout_height="match_parent" />
</LinearLayout>

在最外层的RecyclerView前面新建一个View,然后给他焦点,这样的话,进入订单页初次渲染的时候,最外层的recyclerView就不会被挤出去了.