HarmonyOS鸿蒙开发常用组件详细说明(图片、文本、按钮、弹窗、进度条、文本框)

常用组件

一直会分享,虽然鸿蒙目前来没有多大发展,但不可否然以后发展,华为的技术是一大突破,存在即合理
可以现在没有多大发展。但不可否定未来的发展。

关注’猿来编码‘,微信订阅号,回复 ’组件‘,获取


1、图片

● Image为图片组件,用于在应用中显示图片,参数规则如下:

Image(src: Resource | string)

本地图片
○ 写法一:Image($r(‘app.media.demo’))
对应:entry/src/main/resources/base/media文件夹中要有名为demo的图片
注意:media中图片不允许重名,例如:demo.jpg和demo.png即为重名!

○ 写法二:Image($rawfile(‘demo.png’))
对应:entry/src/main/resources/rawfile文件夹中要有名为demo.png的图片

○ 写法三:Image(‘/images/demo.jpg’)
要求:entry/src/main/ets/images文件夹中要有名为:demo.jpg的图片
注意:ets文件夹为根目录
说明:
● $r函数:
○ 用于获取应用的特定资源文件或数据值的全局函数
○ 参数:特定格式的字符串(一定要根据提示补全编写),格式为:“app.xxx.yyy”
● $rawfile函数
○ 专门用来获取resources/rawfile下的特定文件资源的全局函数
○ 参数:带后缀文件名的字符串(尽量根据提示编写)
● 网络图片:
■ 写法:Image(‘http://xxx/xxx.jpg’)
■ 要注意:真机运行时,要在当前模块的module.json5配置文件中申请网络权限,大致内容如下:

{
   
  "module": {
   
    ***********
    ***********
    "requestPermissions":[ // 申请权限
      {
   "name" : "ohos.permission.INTERNET"}, // 使用网络
    ]
  }
}

● 常用属性:
■ width:宽度 / height:高度
● string : 带长度单位或百分比的字符串, 比如:“20px”、“20vp” 、“50%”
● number:省略长度单位vp的数值, 比如:20
● Resource: 通过 $r(‘app.float.xxx’) 从float.json资源文件中得到的长度值
■ objectFit(图片缩放类型)相关参数如下:
None 保持原有尺寸显示。
Contain 保持宽高比进行缩小或者放大,使得图片完全显示在显示区域内。
Cover 保持宽高比进行缩小或者放大,使得图片完全覆盖显示区域。
Fill 不保持宽高比进行放大缩小,使得图片充满显示区域。
ScaleDown 保持宽高比进行缩小或不变,使得图片完全显示在显示区域内。
Auto 自适应显示
■ interpolation(图片插值,即减轻低清晰度图片在放大显示时出现的锯齿问题。)

长度像素单位
● HarmonyOS中提供的长度像素单位为:px 与 vp
● px: Pixel,屏幕物理像素单位。
○ 问题:相同px值在不同像素密度的手机上显示的尺寸是不同的(如下图所示)
○ 注意:不同于CSS中的px,CSS中的px类似于下面的vp
● vp: Virtual Pixel,虚拟像素
○ 它是屏幕像素密度相关像素
○ 应用运行时,会根据屏幕像素密度转换为屏幕物理像素进行显示
○ 在不同像素密度的手机上,1vp对应的像素数是不同的,像素密度越高,1vp对应的像素数就越多。从而达到:用vp作为长度单位,在尺寸相同但像素密度不同的手机上,显示大小相同。(如下图所示)
○ 当数值不带单位时,默认单位为vp。
○ HarmonyOS提供了针对运行设备的vp与px转换的全局计算函数
■ px2vp(val): 得到指定px值对应的vp值
■ vp2px(val): 得到指定vp值对应的px值

2、文本

概述:文本组件,通常用于展示用户的视图,如显示文章的文字,参数规则如下:

Text(content?: string | Resource)

string字符串:

Text('我是一段文本')

引用Resource资源:
注意:/resources/base/element/string.json中已经配置了test字段

Text($r('app.string.test'))

常用样式:
fontSize 文本大小
fontColor 文本颜色
fontWeight 文字字重
textAlign 文本对齐方式
textOverflow 文本超长时的显示方式。
文字像素单位
● HarmonyOS提供的字体像素单位为:fp
● 官方文档: 与vp类似适用屏幕密度变化,随系统字体大小设置变化
● 真机测试结果:
○ 不会随系统字体大小设置而变化
○ 1fp就等于1vp
**

3、按钮

● 概述:Button是按钮组件,通常用于响应用户的点击操作,其类型包括胶囊按钮、圆形按钮、普通按钮。Button当做为容器使用时可以通过添加子组件实现包含文字、图片等元素的按钮。参数规则如下:

Button(label?: string, options?: {
    type?: ButtonType, stateEffect?: boolean })

● 类型:
Capsule 胶囊型按钮(圆角默认为高度的一半)
Circle 圆形按钮
Normal 普通按钮(默认不带圆角)
● 点击效果:
stateEffect 按压态显示效果,true开启,false关闭,默认true
● 子组件:Button组件也可以有子组件,例如一个带有图标的按钮

 Button({
    type: ButtonType.Capsule, stateEffect: true }) {
   
        Row() {
   
    Text('添加').fontSize(12).fontColor(0xffffff).margin({
    left: 5, right: 12 })
    Image($r('app.media.icon')).width(20).height(20)
  }.alignItems(VerticalAlign.Center).width(90).height(40)
      }

在这里插入图片描述

● 事件

Button('你好').onClick(()=>{
   
  console.log('hello!')
})

切换按钮
● 概述:勾选框样式、状态按钮样式及开关样式,参数规则如下:
● 属性:
selectedColor:设置组件打开状态的背景颜色。
switchPointColor:设置Switch类型的圆形滑块颜色。

Toggle(options: {
    type: ToggleType, isOn?: boolean })
//按钮组件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值