PorterDuff.Mode的16种模式示意图

本文介绍如何利用Xfermode中的PorterDuffXfermode实现DST_IN混合模式,通过具体代码示例展示如何在Canvas上绘制带有特定混合效果的位图。

使用Xfermode时传入mode,类似:
Canvas canvas = new Canvas(dstBitmap);
Xfermode mXfermode = new PorterDuffXfermode(Mode.DST_IN);
mPaint.setXfermode(mXfermode);
canvas.drawBitmap(srcBitmap, 0f, 0f, mPaint);

下面这张演示图网上很多,为了方便查找,所以保存在子集的博客里.

这里写图片描述

逐行代码加注释 public void onBindViewHolder(@NonNull ViewHolder holder, int position) { String type = mAddMemberList.get(position); Context context = holder.itemView.getContext(); String avatarDescription = getAvatarDescription(context, type); holder.itemBinding.getRoot().setContentDescription(avatarDescription); RequestManager glide = Glide.with(context); if (position == URI_AVATAR_POSITION && imageUri != null) { holder.itemBinding.ownerAvatarIv.setImageTintMode(PorterDuff.Mode.DST); glide.load(imageUri).override(DisplayUtils.dp2px(context, 56)) .circleCrop().into(holder.itemBinding.ownerAvatarIv); } else if (position == URI_AVATAR_POSITION && imageBytes != null) { holder.itemBinding.ownerAvatarIv.setImageTintMode(PorterDuff.Mode.DST); glide.load(imageBytes).override(DisplayUtils.dp2px(context, 56)) .diskCacheStrategy(DiskCacheStrategy.ALL) .skipMemoryCache(false) .dontAnimate() .circleCrop().into(holder.itemBinding.ownerAvatarIv); } else if (position == URI_AVATAR_POSITION && imageFile != null) { holder.itemBinding.ownerAvatarIv.setImageTintMode(PorterDuff.Mode.DST); glide.load(imageFile).override(DisplayUtils.dp2px(context, 56)) .circleCrop().into(holder.itemBinding.ownerAvatarIv); } else { if (AddMemberType.CUSTOM.equals(type)) { holder.itemBinding.ownerAvatarIv.setImageTintMode(PorterDuff.Mode.SRC_ATOP); glide.load(R.drawable.svg_upload) .centerInside().into(holder.itemBinding.ownerAvatarIv); } else { holder.itemBinding.ownerAvatarIv.setImageTintMode(PorterDuff.Mode.DST); glide.load(getAvatarId(type)).override(DisplayUtils.dp2px(context, 56)) .circleCrop().into(holder.itemBinding.ownerAvatarIv); } } holder.itemBinding.ownerAvatarSelectIv.setVisibility(selectAvatar.equals(type) ? View.VISIBLE : View.GONE); if (mOnItemClickListener != null) { holder.itemView.setTag(type); holder.itemView.setOnClickListener(v -> mOnItemClickListener.onClick(v)); } holder.itemView.setClickable(!isReadOnly); TPAccessibilityUtilsKt.initAccessDelegate(holder.itemView) .setSelectedProvider(() -> selectAvatar.equals(type)) .markAsButton(); }
最新发布
08-05
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值