HarmonyOS实战—实现抖音点赞和取消点赞效果
2023-02-26 10:18:50 时间
1. 双击点赞 和 双击取消点赞
- 如:在抖音中双击屏幕之后就可以点赞,小红心就会变亮
- 把白色和红色的心形图片复制到
media
下
(福利推荐:阿里云、腾讯云、华为云服务器最新限时优惠活动,云服务器1核2G仅88元/年、2核4G仅698元/3年,点击这里立即抢购>>>)
- 需要图片的可以自取,下面白色图片由于没有背景,所以显示的是白色的,下载后鼠标点击就能看见了
- 因为要双击屏幕才能点赞,所以还要给布局组件
id
- 代码实现:
ability_main
<?xml version="1.0" encoding="utf-8"?> <DirectionalLayout ohos:id="$+id:dl" xmlns:ohos="http://schemas.huawei.com/res/ohos" ohos:height="match_parent" ohos:width="match_parent" ohos:alignment="center" ohos:orientation="vertical"> <Image ohos:id="$+id:img" ohos:height="match_content" ohos:width="match_content" ohos:image_src="http://9i0i.com/pic.php?p=$media:white" ohos:background_element="cyan" > </Image> </DirectionalLayout>
MainAbilitySlice
package com.xdr630.listenerapplication6.slice; import com.xdr630.listenerapplication6.ResourceTable; import ohos.aafwk.ability.AbilitySlice; import ohos.aafwk.content.Intent; import ohos.agp.components.Component; import ohos.agp.components.DirectionalLayout; import ohos.agp.components.Image; public class MainAbilitySlice extends AbilitySlice implements Component.DoubleClickedListener { Image image; @Override public void onStart(Intent intent) { super.onStart(intent); super.setUIContent(ResourceTable.Layout_ability_main); //1.找到图片组件 image = (Image) findComponentById(ResourceTable.Id_img); //找到铺满屏幕布局的对象 DirectionalLayout dl = (DirectionalLayout) findComponentById(ResourceTable.Id_dl); //2.给布局添加双击事件 dl.setDoubleClickedListener(this); } @Override public void onActive() { super.onActive(); } @Override public void onForeground(Intent intent) { super.onForeground(intent); } //如果标记为false,表示没有点赞,此时把白色变为红色 //如果标记为true,表示已经点赞,再次双击后,会把红色变回白色 boolean flag = false; @Override public void onDoubleClick(Component component) { //修改图片的红星就可以了,只需要用到image就行了,所以把image定为成员变量 if (flag){ image.setImageAndDecodeBounds(ResourceTable.Media_white); //取消点赞变成白色,也要把flag设置为false flag = false; }else{ image.setImageAndDecodeBounds(ResourceTable.Media_red); //当启动项目的时候,flag初始值是false,就会走下面的else的代码,变成红色后就要把flag变成true了 flag = true; } } }
- 运行:
- 双击屏幕点赞:
- 双击屏幕后取消点赞:
2. 能否按照抖音的业务去实现呢?
业务分析:
- 双击屏幕之后点赞。(上面已实现),再次双击屏幕之后,不会取消点赞,只有点击后红心之后才能取消点赞。
- 单击红心也可以点赞,再次单击红心就会取消点赞
实现思路:
- 给最外层的布局添加双击事件,双击之后点赞,变成红色心。
如果已经被点赞,那么还是修改为红色心,相当于不做任何处理。
- 给图片添加单击事件。
如果没有点赞,单击之后,白色心变成红色心。
如果已经点赞了,单击之后,红色心变成白色心。
- 代码实现:
上面布局文件不变,MainAbilitySlice 如下:
- 给布局添加双击事件,因为再次双击不会取消点赞,所以把
else
代码里设置为红色后就把flag
取反去掉,就不会出现再次双击取消点赞了。 - 给图片添加单击事件,因为涉及到点赞后为红色,再取消就变为白色,所以要把
flag
变为相反的操作
package com.xdr630.listenerapplication6.slice; import com.xdr630.listenerapplication6.ResourceTable; import ohos.aafwk.ability.AbilitySlice; import ohos.aafwk.content.Intent; import ohos.agp.components.Component; import ohos.agp.components.DirectionalLayout; import ohos.agp.components.Image; public class MainAbilitySlice extends AbilitySlice implements Component.DoubleClickedListener, Component.ClickedListener { Image image; @Override public void onStart(Intent intent) { super.onStart(intent); super.setUIContent(ResourceTable.Layout_ability_main); //1.找到图片组件 image = (Image) findComponentById(ResourceTable.Id_img); //找到铺满屏幕布局的对象 DirectionalLayout dl = (DirectionalLayout) findComponentById(ResourceTable.Id_dl); //2.给布局添加双击事件 dl.setDoubleClickedListener(this); //3.给图片添加单击事件 image.setClickedListener(this); } @Override public void onActive() { super.onActive(); } @Override public void onForeground(Intent intent) { super.onForeground(intent); } //如果标记为false,表示没有点赞,此时把白色变为红色 //如果标记为true,表示已经点赞,再次双击后,会把红色变回白色 boolean flag = false; @Override public void onDoubleClick(Component component) { //修改图片的红星就可以了,只需要用到image就行了,所以把image定为成员变量 if (flag){ image.setImageAndDecodeBounds(ResourceTable.Media_white); //取消点赞变成白色,也要把flag设置为false flag = false; }else{ image.setImageAndDecodeBounds(ResourceTable.Media_red); //当启动项目的时候,flag初始值是false,就会走下面的else的代码,此时设置为红色,把flag去掉,再次双击后就还是红色了 } } @Override public void onClick(Component component) { if (flag){ image.setImageAndDecodeBounds(ResourceTable.Media_white); flag = false; }else{ image.setImageAndDecodeBounds(ResourceTable.Media_red); flag = true; } } }
- 运行:
- 单击红心后:
- 再次单击红心:
- 双击屏幕后效果如下,再次双击屏幕就不会取消点赞了,只有点击小红心才能取消点赞
你还在原价购买阿里云、腾讯云、华为云、天翼云产品?那就亏大啦!现在申请成为四大品牌云厂商VIP用户,可以3折优惠价购买云服务器等云产品,并且可享四大云服务商产品终身VIP优惠价,还等什么?赶紧点击下面对应链接免费申请VIP客户吧:
相关文章
- Taro框架实现微信登录及获取手机号和用户信息
- [koreader]statistics插件之博客阅读统计模块
- 蓝桥杯寒假集训第五天(子串分值和)
- Webpack解析文件和资源
- Webpack中的文件监听与热更新
- 【愚公系列】2023年01月 Dapr分布式应用运行时-Dapr的安装
- 视频处理系列︱利用达摩院ModelScope进行视频人物分割+背景切换(一)
- SAP UI5 FlexBox Layout 布局的概念和具体使用案例介绍试读版
- 如何配置 jad,让 Eclipse 可以自动显示反编译之后的 .class 源代码
- 使用 SAP UI5 3D Viewer 控件显示 3D 模型效果试读版
- 【Django | 爬虫 】收集某吧评论集成舆情监控(附源码)
- 自建服务器远程游玩PS5不踩坑指南
- Redis发布订阅和事务实现原理
- 第十四届蓝桥杯集训——数组(一维)
- IP协议重点总结(附实例)
- 浅谈单元测试
- 假如面试官问你Babel的原理该怎么回答1
- vivo 服务端监控体系建设实践
- 挖掘研发项目协作痛点 UniPro“串联”人和事
- 振弦采集模块辅助功能寄存器