温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

使用Android怎么实现淘宝商品列表长按遮罩效果

发布时间:2021-05-27 17:11:46 来源:亿速云 阅读:162 作者:Leah 栏目:移动开发

使用Android怎么实现淘宝商品列表长按遮罩效果?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

长按条目时,弹出遮罩的效果遮挡在原来的条目布局上; 页面滑动或点击其他的条目,上一个正在遮罩的条目遮罩消失。 长按其他条目时,上一个遮罩的条目撤销遮罩,当前长按的显示遮罩; 条目添加遮罩的时添加动画;

1. 遮罩的效果,我们会很容易的想到Android布局控件FrameLayout布局,是基于叠加在上方的布局。所以在列表条目布局的时候,可以使用FrameLayout布局,在长按列表条目时,用条目的根布局添加一个遮罩的布局,就达到我们想要的效果了。

使用Android怎么实现淘宝商品列表长按遮罩效果

2. 记录当前长按的根布局,如果点击或长按其他的列表条目,亦或滑动页面(添加活动监听)时,就取消之前长按的条目遮罩,从条目根布局中删除遮罩布局就OK了;

3. 可以利用View动画或属性动画,在添加遮罩布局时显示动画;

接下来, 来撸一下代码吧:

1. 首先,先定义一下遮罩的布局,根据需求自定义View

/***  * 长按条目遮罩界面  */ public class ItemMaskLayout extends LinearLayout {   public ItemMaskLayout(Context context) {     this(context, null);   }   public ItemMaskLayout(Context context, @Nullable AttributeSet attrs) {     this(context, attrs, 0);   }   public ItemMaskLayout(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {     super(context, attrs, defStyleAttr);     LayoutInflater.from(context).inflate(R.layout.layout_product_list_item_mask, this, true);     findViewById(R.id.tv_find_same).setOnClickListener(new OnClickListener() {       @Override       public void onClick(View v) {         if (mItemMaskClickListener != null) {           mItemMaskClickListener.findTheSame();         }       }     });     findViewById(R.id.tv_collection).setOnClickListener(new OnClickListener() {       @Override       public void onClick(View v) {         if (mItemMaskClickListener != null) {           mItemMaskClickListener.collection();         }       }     });   }   public ItemMaskClickListener mItemMaskClickListener;   public void setMaskItemClickListener(ItemMaskClickListener listener) {     this.mItemMaskClickListener = listener;   }   //提供遮罩中按钮点击操作接口 自定义   public interface ItemMaskClickListener {     void findTheSame();     void collection();   } }

2. 封装一个帮助类,主要是根据该类的成员变量根据长按的条目指向列表Item的布局,然后为条目添加遮罩的效果;

/**  * 长按条目添加遮罩操作帮助类  */ public class ItemLongClickMaskHelper {   private FrameLayout mRootFrameLayout;   private ItemMaskLayout mMaskItemLayout;   private Context mContext;   private ScaleAnimation anim;   private String productId;   public ItemLongClickMaskHelper(Context context){     this.mContext = context;     mMaskItemLayout = new ItemMaskLayout(mContext);     anim = new ScaleAnimation(         0f, 1.0f, 1.0f, 1.0f,         Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f     );     anim.setDuration(300);     mMaskItemLayout.setOnClickListener(new View.OnClickListener() {       @Override       public void onClick(View v) {         dismissItemMaskLayout();       }     });     mMaskItemLayout.setOnLongClickListener(new View.OnLongClickListener() {       @Override       public boolean onLongClick(View v) {         dismissItemMaskLayout();         return true;       }     });     mMaskItemLayout.setMaskItemClickListener(new ItemMaskLayout.ItemMaskClickListener() {       @Override       public void findTheSame() {         ToastUtil.showCustomToast("找相似 " + productId);       }       @Override       public void collection() {         ToastUtil.showCustomToast("收藏 " + productId);       }     });   }   public ItemLongClickMaskHelper setRootFrameLayout(FrameLayout frameLayout, String fundId){     if (mRootFrameLayout != null){       mRootFrameLayout.removeView(mMaskItemLayout);     }     mRootFrameLayout = frameLayout;     this.productId = fundId;     mRootFrameLayout.addView(mMaskItemLayout);     mMaskItemLayout.startAnimation(anim);     return this;   }   public ItemLongClickMaskHelper setMaskItemListener(ItemMaskLayout.ItemMaskClickListener listener){     this.mMaskItemLayout.setMaskItemClickListener(listener);     return this;   }   /**    * 遮罩消失    */   public void dismissItemMaskLayout(){     if (mRootFrameLayout != null){       mRootFrameLayout.removeView(mMaskItemLayout);     }   } }

3.注意在滑动RecyclerView列表的时候,监听滑动,撤销遮罩,直接定义RecyclerView的子类,添加滑动监听回调;

public class TouchCallbackRecyclerView extends RecyclerView {    public TouchCallbackRecyclerView(Context context) {     super(context);   }   public TouchCallbackRecyclerView(Context context, @Nullable AttributeSet attrs) {     super(context, attrs);   }   public TouchCallbackRecyclerView(Context context, @Nullable AttributeSet attrs, int defStyle) {     super(context, attrs, defStyle);   }   public interface ScrollCallback {     /**      * 滑动手指抬起事件      *      * @param diffY 抬起时相对于按下时的偏移量<br/>大于0:列表往下拉, 小于0: 列表往上拉      */     void onTouchUp(float diffY);   }   private ScrollCallback mScrollCallback;   public void setScrollCallback(ScrollCallback callback) {     this.mScrollCallback = callback;   }   private float mDownY, mMovingY, mUpY;   private boolean isUp = false;   @SuppressWarnings("deprecation")   private static final float SLOP = ViewConfiguration.getTouchSlop();   @Override   public boolean dispatchTouchEvent(MotionEvent ev) {     switch (ev.getAction()) {       case MotionEvent.ACTION_DOWN:         mDownY = ev.getY();         isUp = false;         break;       case MotionEvent.ACTION_MOVE:         mMovingY = ev.getY();         isUp = false;         break;       case MotionEvent.ACTION_UP:         mUpY = ev.getY();         isUp = true;         break;     }     if (isUp && mScrollCallback != null && Math.abs(mUpY - mDownY) > SLOP) {       mScrollCallback.onTouchUp(mMovingY - mDownY);     }     return super.dispatchTouchEvent(ev);   } }

看完上述内容,你们掌握使用Android怎么实现淘宝商品列表长按遮罩效果的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI