[文章]HarmonyOS实战—点击更换随机图片

阅读量0
0
2
单击随机更换图片
  • 点击按钮就会更换一张图片

实现案例:
  • 新建项目:ImageSwitchApplication
思路分析:
  • 准备好几张图片复制到 media 中
  • 如果要获取text文本里面的汉字就可以使用资源管理器,但是现在不需要图片里的每个字节,要的是图片的整体,就不需要用资源管理器去读了,直接用ResourceTable来获取就行了
  • 存储图片使用集合更方便,因为图片可能有很多张,数组还要确定长度,有点不方便,所以用集合
  • 可以看到图片是int类型的,所以集合用 Integer
  • 在 onClick 方法当中要用到 img 组件对象、还要创建的集合对象,所以要把这两者定为成员变量,onClick 方法才能使用
代码实现:
ability_main
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <DirectionalLayout
  3.     xmlns:ohos="http://schemas.huawei.com/res/ohos"
  4.     ohos:height="match_parent"
  5.     ohos:width="match_parent"
  6.     ohos:alignment="center"
  7.     ohos:orientation="vertical">

  8.     <Image
  9.         ohos:id="$+id:img"
  10.         ohos:height="match_content"
  11.         ohos:width="match_content">

  12.     </Image>

  13.     <Button
  14.         ohos:id="$+id:but1"
  15.         ohos:height="match_content"
  16.         ohos:width="match_content"
  17.         ohos:text="点我"
  18.         ohos:text_size="150"
  19.         ohos:background_element="red"
  20.         >

  21.     </Button>

  22. </DirectionalLayout>
复制代码

MainAbilitySlice
  1. package com.xdr630.imageswitchapplication.slice;

  2. import com.xdr630.imageswitchapplication.ResourceTable;
  3. import ohos.aafwk.ability.AbilitySlice;
  4. import ohos.aafwk.content.Intent;
  5. import ohos.agp.components.Button;
  6. import ohos.agp.components.Component;
  7. import ohos.agp.components.Image;

  8. import java.util.ArrayList;
  9. import java.util.Random;

  10. public class MainAbilitySlice extends AbilitySlice implements Component.ClickedListener {

  11.     ArrayList<Integer> list = new ArrayList<>();
  12.     Image img;
  13.     @Override
  14.     public void onStart(Intent intent) {
  15.         super.onStart(intent);
  16.         super.setUIContent(ResourceTable.Layout_ability_main);

  17.         //定义一个数组或者集合来存储所有图片

  18.         list.add(ResourceTable.Media_girl1);
  19.         list.add(ResourceTable.Media_girl2);
  20.         list.add(ResourceTable.Media_girl3);
  21.         list.add(ResourceTable.Media_girl4);
  22.         list.add(ResourceTable.Media_girl5);
  23.         list.add(ResourceTable.Media_girl6);
  24.         list.add(ResourceTable.Media_girl7);
  25.         list.add(ResourceTable.Media_girl8);
  26.         list.add(ResourceTable.Media_girl9);

  27.         //找到组件
  28.         img = (Image) findComponentById(ResourceTable.Id_img);
  29.         Button but1 = (Button) findComponentById(ResourceTable.Id_but1);

  30.         //给按钮绑定单击事件
  31.         but1.setClickedListener(this);
  32.     }

  33.     @Override
  34.     public void onActive() {
  35.         super.onActive();
  36.     }

  37.     @Override
  38.     public void onForeground(Intent intent) {
  39.         super.onForeground(intent);
  40.     }

  41.     @Override
  42.     public void onClick(Component component) {
  43.         //当按钮被点击之后,需要修改图片的内容
  44.         Random r = new Random();
  45.         int index = r.nextInt(list.size());
  46.         //通过随机索引,可以获取随机元素
  47.         int randomImg = list.get(index);
  48.         //把获取到的随机图片设置给Image组件就可以了
  49.         img.setImageAndDecodeBounds(randomImg);
  50.     }
  51. }
复制代码

  • 运行:
  • 也可以进一步扩展:点击图片时就可以查看详细信息。
【本文正在参与“有奖征文 | HarmonyOS征文大赛”活动】https://bbs.elecfans.com/jishu_2098584_1_1.html

回帖

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容图片侵权或者其他问题,请联系本站作侵删。 侵权投诉
链接复制成功,分享给好友