本实例主要通过BlendMode属性来实现挂件和图片的混合,通过更改不同的混合参数,能够展示不同的混合效果。
使用说明 :
首先将挂件Image组件绑定BlendMode属性,currentBlendMode控制混合模式更改的变量,初始化为BlendMode.NONE,不进行任何混合操作, 点击挂件区域,切换不同的混合模式达到不同的混合效果。
Image(this.currentUserPendant)
.width($r('app.integer.blend_mode_image_size'))
.height($r('app.integer.blend_mode_image_size'))
.borderRadius($r('app.integer.blend_mode_image_border_radius'))
.blendMode(this.currentBlendMode, BlendApplyType.OFFSCREEN)
if (this.currentBlendMode === item.blendMode) {
this.currentBlendMode = BlendMode.DST;
this.currentUserPendant = '';
this.currentIndex = -1;
return;
}
// TODO:知识点:点击切换混合模式
this.currentIndex = index;
this.currentUserPendant = item.pendantImage;
this.currentBlendMode = item.blendMode;
数据通过LazyForEach进行遍历。
blendmode // har类型
|---model
| |---DataSource.ets // 数据资源
| |---DataType.ets // 数据类型
| |---MockData.ets // 模拟数据
|---view
| |---BlendModeView.ets // 视图层-应用主页面
本实例依赖common模块来实现日志的打印、资源 的调用、依赖动态路由模块来实现页面的动态加载。
如果大家觉得这篇内容对学习鸿蒙开发有帮助,我想邀请大家帮我三个小忙:
点赞,转发,有你们的 『点赞和评论』,才是我创造的动力。
关注小编,同时可以期待后续文章ing?,不定期分享原创知识。
更多鸿蒙最新技术知识点,请关注作者博客:鸿蒙实战经验分享:鸿蒙基础入门开发宝典! (qq.com)
更多回帖