「Mac畅玩鸿蒙与硬件40」UI互动应用篇17 - 照片墙布局

简介: 本篇将带你实现一个简单的照片墙布局应用,通过展示多张图片组成照片墙效果,用户可以点击图片查看其状态变化。

本篇将带你实现一个简单的照片墙布局应用,通过展示多张图片组成照片墙效果,用户可以点击图片查看其状态变化。

20241130_223227.gif


关键词
  • UI互动应用
  • 照片墙布局
  • Grid 布局
  • 动态图片加载
  • 用户交互

一、功能说明

照片墙布局应用的特点:

  1. 动态加载多张图片组成网格布局。
  2. 用户点击图片时,能够查看对应的图片状态(如编号)。

二、所需组件

  • @Entry@Component 装饰器
  • Grid 布局组件用于照片墙布局
  • Image 组件用于动态加载图片
  • Text 组件用于显示状态信息
  • @State 修饰符用于状态管理

三、项目结构

  • 项目名称PhotoWallApp
  • 自定义组件名称PhotoWallPage
  • 代码文件PhotoWallPage.etsIndex.ets

四、代码实现

// 文件名:PhotoWallPage.ets

@Component
export struct PhotoWallPage {
   
  @State selectedImage: string = ''; // 记录选中的图片路径
  @State isPreviewVisible: boolean = false; // 是否显示图片预览
  @State previewImage: string = ''; // 预览图片路径
  private images: string[] = [
    'light_on_1', 'light_on_2', 'light_on_3',
    'light_on_4', 'light_on_5', 'light_on_6'
  ]; // 图片资源名称

  build() {
   
    Row({
    space: 20 }) {
   
      // 预览区域:放置预览图
      Column({
    space: 10}) {
   
        if (this.isPreviewVisible) {
   
          Image(this.getImagePath(this.previewImage))
            .width('100%') // 设置预览图宽度为父容器的 100%
            .height('80%')
            .borderRadius(8)
            .objectFit(ImageFit.Contain) // 保证图片按比例显示
            .zIndex(2); // 设置图片的层级高于遮罩层

          Text(this.selectedImage)
            .fontSize(20) // 平板设备调整字体大小
            .fontColor(Color.Blue)
            .alignSelf(ItemAlign.Center)
            .margin({
    top: 20 })
        }
      }
      .width('40%') // 设置预览区的宽度占 40%
      .height('100%')
      .padding(10)
      .alignSelf(ItemAlign.Center)

      // 照片墙区域:展示图片墙
      Column({
    space: 20 }) {
   
        // 照片墙标题
        Text('照片墙布局')
          .fontSize(28) // 调整字体大小适合平板
          .fontWeight(FontWeight.Bold)
          .alignSelf(ItemAlign.Center)
          .margin({
    top: 20 });

        // 使用 Grid 渲染动态图片
        Grid() {
   
          ForEach(this.images, (image: string) => {
   
            GridItem() {
   
              Row({
    space: 10 }) {
   
                // 使用统一大小的图片,添加懒加载或占位图提升性能
                Image(this.getImagePath(image))  // 动态加载图片
                  .width('90px') // 适应平板屏幕宽度
                  .height('90px') // 保持统一的高度
                  .borderRadius(8)
                  .onClick(() => this.showPreview(image)) // 点击图片显示预览
                  .objectFit(ImageFit.Contain); // 保证图片显示不变形
              }
            }
          });
        }
        .padding(10)
        .width('100%')
        .height('auto') // 保证 Grid 自适应高度

        // 预览区域:放置预览图
        Column({
    space: 10}) {
   
          if (this.isPreviewVisible) {
   
            Image(this.getImagePath(this.previewImage))
              .width('100%') // 设置预览图宽度为父容器的 100%
              .height('80%')
              .borderRadius(8)
              .objectFit(ImageFit.Contain) // 保证图片按比例显示
              .zIndex(2); // 设置图片的层级高于遮罩层
          }
        }
        .width('40%') // 设置预览区的宽度占 40%
        .height('100%')
        .padding(10)
        .alignSelf(ItemAlign.Center)

      }
      .width('60%') // 照片墙区域宽度占 60%
      .height('100%')
      .padding(10)
      .backgroundColor('#F8F8F8') // 设置浅色背景
    }
    .width('100%')
    .height('100%');
  }

  // 获取图片的完整路径
  private getImagePath(image: string): Resource {
   
    return $r(`app.media.${
     image}`);
  }

  // 显示图片预览
  private showPreview(image: string) {
   
    this.previewImage = image;
    this.isPreviewVisible = true;
    this.selectedImage = image;  // 更新选中的图片
  }
}
// 文件名:Index.ets

import {
    PhotoWallPage } from './PhotoWallPage';

@Entry
@Component
struct Index {
   
  build() {
   
    Column() {
   
      PhotoWallPage() // 调用照片墙页面
    }
    .padding(20)
  }
}

效果示例:通过网格布局展示多张图片,用户点击某张图片后,状态文本会更新显示该图片的编号。

20241130_223227.gif


五、代码解读

  • 动态图片加载:通过 ForEach 渲染动态图片列表,并为每张图片绑定点击事件。
  • 状态管理:使用 @State selectedImage 动态更新用户点击的图片状态。
  • 网格布局:使用 Grid 实现照片墙的整齐排列。

六、优化建议

  1. 添加图片放大功能:点击图片后可显示放大的版本,提升用户体验。
  2. 图片动态更新:允许用户上传图片或从图库加载更多图片。
  3. 自定义布局样式:提供多种照片墙布局选择,如横向滚动或不同尺寸的网格组合。

七、相关知识点


小结

通过照片墙布局应用的实现,用户可以学习动态图片加载、状态管理和网格布局的基本用法。


下一篇预告

在下一篇「UI互动应用篇18 - 多滑块联动控制器」中,我们将探索如何实现多个滑块之间的联动控制,并动态显示各滑块的状态。


上一篇: 「Mac畅玩鸿蒙与硬件39」UI互动应用篇16 - 倒计时环形进度条

下一篇: 「Mac畅玩鸿蒙与硬件41」UI互动应用篇18 - 多滑块联动控制器


作者:SoraLuna
链接:https://www.nutpi.net/thread?topicId=341
來源:坚果派
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


目录
相关文章
|
21天前
「Mac畅玩鸿蒙与硬件51」UI互动应用篇28 - 模拟记账应用
本篇教程将介绍如何创建一个模拟记账应用,通过账单输入、动态列表展示和实时统计功能,学习接口定义和组件间的数据交互。
152 68
|
20天前
|
UED
「Mac畅玩鸿蒙与硬件52」UI互动应用篇29 - 模拟火车票查询系统
本篇教程将实现一个模拟火车票查询系统,通过输入条件筛选车次信息,并展示动态筛选结果,学习事件处理、状态管理和界面展示的综合开发技巧。
57 13
|
19天前
「Mac畅玩鸿蒙与硬件53」UI互动应用篇30 - 打卡提醒小应用
本篇教程将实现一个打卡提醒小应用,通过用户输入时间进行提醒设置,并展示实时提醒状态,实现提醒设置和取消等功能。
55 10
|
23天前
|
存储 人工智能 JavaScript
Harmony OS开发-ArkTS语言速成二
本文介绍了ArkTS基础语法,包括三种基本数据类型(string、number、boolean)和变量的使用。重点讲解了let、const和var的区别,涵盖作用域、变量提升、重新赋值及初始化等方面。期待与你共同进步!
88 47
Harmony OS开发-ArkTS语言速成二
|
25天前
|
API 索引
鸿蒙开发:实现一个超简单的网格拖拽
实现拖拽,最重要的三个方法就是,打开编辑状态editMode,实现onItemDragStart和onItemDrop,设置拖拽移动动画和交换数据,如果想到开启补位动画,还需要实现supportAnimation方法。
76 13
鸿蒙开发:实现一个超简单的网格拖拽
|
24天前
|
索引 API
鸿蒙开发:自定义一个股票代码选择键盘
金融类的软件,特别是股票基金类的应用,在查找股票的时候,都会有一个区别于正常键盘的键盘,也就是股票代码键盘,和普通键盘的区别就是,除了常见的数字之外,也有一些常见的股票代码前缀按钮,方便在查找股票的时候,更加方便的进行检索。
鸿蒙开发:自定义一个股票代码选择键盘
|
24天前
|
API
鸿蒙开发:自定义一个英文键盘
实现方式呢,有很多种,目前采用了比较简单的一种,如果大家采用网格Grid组件实现方式,也是可以的,但是需要考虑每行的边距以及数据,还有最后两行的格子占位问题。
鸿蒙开发:自定义一个英文键盘
|
25天前
|
存储 JSON 数据库
鸿蒙元服务项目实战:备忘录内容编辑开发
富文本内容编辑我们直接使用RichEditor组件即可,最重要的就是参数,value: RichEditorOptions,通过它,我们可以用来设置样式,和获取最后的富文本内容,这一点是很重要的。
鸿蒙元服务项目实战:备忘录内容编辑开发
|
23天前
|
前端开发 API 数据库
鸿蒙开发:异步并发操作
在结合async/await进行使用的时候,有一点需要注意,await关键字必须结合async,这两个是搭配使用的,缺一不可,同步风格在使用的时候,如何获取到错误呢,毕竟没有catch方法,其实,我们可以自己创建try/catch来捕获异常。
鸿蒙开发:异步并发操作
|
23天前
|
API
鸿蒙开发:实现popup弹窗
目前提供了两种方式实现popup弹窗,主推系统实现的方式,几乎能满足我们常见的所有场景,当然了,文章毕竟有限,尽量还是以官网为主。
鸿蒙开发:实现popup弹窗