第十节HarmonyOS 常用基础组件-Image

news/2024/7/21 9:48:23 标签: harmonyos, 华为

一、组件介绍

        组件(Component)是界面搭建与显示的最小单位,HarmonyOS ArkUI声名式为开发者提供了丰富多样的UI组件,我们可以使用这些组件轻松的编写出更加丰富、漂亮的界面。

        组件根据功能可以分为以下五大类:基础组件、容器组件、媒体组件、绘制组件、画布组件。其中基础组件时视图层的基本组成单位,包括Text、Image、TextInput、Buttton、LoadingProgress等。

下面我们将分别介绍这些常用基础组件的使用:

  • Image

        Image组件用来渲染展示图片,它可以让界面变得更加丰富多彩。只需要给Image组件设置图片地址、宽和高,图片就能加载出来,示例如下:

@Entry
@Component
struct Index {
  @State message: string = 'Hello World';

  build() {
    Row() {
      Column() {
        Image($r("app.media.startIcon"))
          .width(100)
          .height(100)
          .backgroundColor(Color.Red)
      }
      .width('100%')
    }
    .height('100%')
  }
}

效果图如下:

  1. 设置缩放类型

        为了使图片在页面中有更好的显示效果,有时候需要对图片进行缩放处理。您可以使用objectFit属性设置图片的缩放类型,objectFit的参数类型为ImageFit。

原图:

        将图片加载到Image组件,设置宽高,设置objectFit为Cover(默认值),设置图片背景色为灰色0xCCCCCC。示例代码如下

.objectFit(ImageFit.Cover)

ImageFit包含以下几种类型:

  • Contain保持宽高比进行缩小或者放大,使得图片完全显示在显示边界内。
    .objectFit(ImageFit.Contain)
  • Cover(默认值):保持宽高比进行缩小或者放大,使得图片两边都大于或等于显示边界。
.objectFit(ImageFit.Cover)

  • Auto:自适应显示。
.objectFit(ImageFit.Auto)

  • Fill:不保持宽高比进行放大缩小,使得图片充满显示边界。
.objectFit(ImageFit.Fill)

  • ScaleDown:保持宽高比显示,图片缩小或者保持不变。
.objectFit(ImageFit.ScaleDown)

  • None:保持原有尺寸显示。
.objectFit(ImageFit.None)

三、加载网络图片

        Image组件支持加载网络图片,将图片地址换成网络图片地址进行加载。

Image('https://www.baiidu.com/xxx.jpg')

为了成功加载网络图片,您需要在module.json5文件中申明网络访问权限。

{
  "module": {
    ......
    "requestPermissions": [
      {
        "name": "ohos.permission.INTERNET"
      }
    ]
  }
}

说明:

        应用访问网络需要申请ohos.permission.INTERNET权限,因为HarmonyOS提供了一种访问控制机制即应用权限,用来保证这些数据或功能不会被不当或恶意使用。

代码:

@Entry
@Component
struct Index {
  @State message: string = 'Hello World';

  build() {
    Row() {
      Column() {
        Image("https://t7.baidu.com/it/u=1595072465,3644073269&fm=193&f=GIF")
          .width(200)
          .height(200)
          .objectFit(ImageFit.Fill)
          .backgroundColor(Color.Red)

      }
      .width('100%')
    }
    .height('100%')
  }
}

效果图:


http://www.niftyadmin.cn/n/5231581.html

相关文章

uni-app 微信小程序 电子签名及签名图片翻转显示功能

文章目录 1. 需求背景2. 开始撸2.1 点击 重写 进入签名页面(上图一)2.2 书写签名,点击确认返回,及图片翻转显示(上图二,三) 3. 图片进行翻转,返回翻转后的图片 1. 需求背景 接的一个…

Python----文件备份案例

实例代码 # 1、接收用户输入的文件名(要备份的文件名) oldname input(请输入要备份的文件名称:) # python.txt # 2、规划备份文件名(python[备份].txt) # 搜索点号 index oldname.rfind(.) # 返回文件名和文件后缀 …

Django回顾4

一.过滤器 1.过滤器格式 {{变量|过滤器名字}} 2.怎么使用 1.注册app 2.在app下创建templatetags模块(模块名只能是templatetags) 3.在包下写一个py文件,随便命名 4.在py文件中写入:from django import template …

LLM与知识图谱的协同与互补

文章目录 背景介绍LLM影响力与潜在问题LLMs和KGs的优缺点 大语言模型(LLMs)only-encoder架构encoder-decoder架构decoder-only架构 提示工程知识图谱LLM和知识图谱的代表性应用分类用知识图谱增强 LLM用知识图谱增强 LLM 预训练将知识图谱集成到训练目标…

九章量子计算机:探索量子世界的革命性工具

九章量子计算机:探索量子世界的革命性工具 一、引言 九章量子计算机的推出,是近年来科技界最为引人瞩目的成就之一。这款基于量子力学的计算机,以其独特的计算方式和潜在的应用前景,引发了全球范围内的关注和讨论。本文将深入探讨九章量子计算机的原理、技术特点、应用前景…

英语助教求职简历模板(通用10篇)

以下10篇简历内容以英语助教招聘需求为背景制作,大家可以借鉴参考,希望能帮助大家在众多候选人中脱颖而出。 英语助教求职简历下载(可在线制作):百度幻主简历 英语助教简历1: 求职意向 求职类型:全职 …

golang函数的返回值

函数可以有0或多个返回值,返回值需要指定数据类型,返回值通过return关键字来指定。 return可以有参数,也可以没有参数,这些返回值可以有名称,也可以没有名称。go中的函数可以有多个返回值。 return关键字中指定了参数时…

JMX的使用

1. 定义和意义 JMX是Java Management Extention的缩写,出发点是让外部通过属性/方法来读取或设置程序状态。对于提供对外服务的程序来说,天生就有这样的能力,Web程序通过HTTP接口对外暴露,RPC应用通过RPC接口暴露。不过带来的问…