界面开发
data:image/s3,"s3://crabby-images/d5d5a/d5d5a54c700cdf54073d2bc33ac0d8a30c6bcee0" alt=""
data:image/s3,"s3://crabby-images/32c8b/32c8b82e082492e17c84510ff181c7e459843404" alt=""
ts
//构建 → 界面
build() {
//行
Row(){
//列
Column(){
//文本 函数名(参数) 对象.方法名(参数) 枚举名.变量名
Text(this.message)
.fontSize(40)//设置文本大小
.fontWeight(FontWeight.Bold)//设置文本粗细
.fontColor('#ff2152')//设置文本颜色
}.width('100%')
}.height('100%')
}
界面开发-布局思路
data:image/s3,"s3://crabby-images/02755/02755b3cda6b5c6ebbcc7218da862480cd3bddd0" alt=""
data:image/s3,"s3://crabby-images/644a7/644a703d3da626b16467737424fad8dba4bf3a4b" alt=""
ts
//构建 → 界面
build() {
//布局思路:先布局在排版
Column(){
//内容
Text('小说简介')
Row(){
Text('都市')
Text('生活')
Text('情感')
Text('男频')
}
}//最外面只能有一层容器组件,需要编写要在容器内编写
}
data:image/s3,"s3://crabby-images/eafd8/eafd890e1fa4bcab6655053f53ea376f78cd6c4a" alt=""
属性方法
data:image/s3,"s3://crabby-images/868e6/868e69ca75596d2ca667353aefc27995ea6716e5" alt=""
ts
//构建 → 界面
build() {
//布局思路:先布局在排版
Column(){
//内容
Text('小说简介')
.width('100%')
.fontSize(25)
.fontWeight(FontWeight.Bolder)
.height(50)
Row(){
Text('都市')
.fontColor(Color.Blue)
.backgroundColor(Color.Brown)
.width(50)
.height(40)
Text('生活')
.fontColor(Color.Brown)
.backgroundColor(Color.Green)
.width(50)
.height(40)
Text('情感')
.backgroundColor(Color.Pink)
.width(50)
.height(40)
Text('男频')
.backgroundColor(Color.Orange)
.width(50)
.height(40)
}.width('100%')
}//最外面只能有一层容器组件,需要编写要在容器内编写
}
data:image/s3,"s3://crabby-images/f446c/f446c20c025a6471712bf1da0fbb46264cf05d1f" alt=""
字体颜色
data:image/s3,"s3://crabby-images/bba32/bba32086ada4f91973ba0534bdb6aef684f25e21" alt=""
ts
//2、综合练习:今日头条置顶新闻
Column(){
Text('学鸿蒙,就来陈哈哈~')
.fontSize(15)
.width('100%')
.fontWeight(FontWeight.Bold)
.height(25)
Row(){
Text('置顶')
.fontColor(Color.Red)
.fontSize(10)
.width(30)
Text('新华社')
.fontSize(10)
.fontColor('#888')
.width(40)
Text('4680评论')
.fontSize(10)
.fontColor('#888')
.width(50)
}.width('100%')
}.width('100%')
data:image/s3,"s3://crabby-images/b1f34/b1f34f09358330e5b647060d7a6a6db8fa19f4bd" alt=""
文字溢出省略号、行高
data:image/s3,"s3://crabby-images/1d79f/1d79f97f083b474a7afb9ec5e0714b75f6719bd4" alt=""
ts
Column(){
Text('HarmonyOS开发初体验')
.width('100%')
.fontWeight(FontWeight.Bold)
.lineHeight(50)
.fontSize(24)
Text('方舟开发框架(简称ArkUI)为HarmonyOS应用的UI开发提供了完整的基础设施,包括简洁的UI语法、丰富的UI功能(组件、布局、动画以及交互事件),以及实时界面预览工具等,可以支持开发者进行可视化界面开发。')
.width('100%')
.lineHeight(24)
.fontColor('#888')
//重点记忆溢出省略号
.textOverflow({
overflow:TextOverflow.Ellipsis
}).maxLines(2)//配合使用能见度两行
}
data:image/s3,"s3://crabby-images/a7659/a765935472a3d2eba0c562d870356257139bf5ce" alt=""
Image图片组件
data:image/s3,"s3://crabby-images/c46d5/c46d5886b5012ed5b550c646e8383c8a0cb455a9" alt=""
ts
//构建 → 界面
build() {
//1、网络图片加载 image('网图地址')
// Column(){
// Image('https://www.itheima.com/images/logo.png')
// .width(200)
// }
//2、本地图片加载 image($r('app.media.文件名'))
Column(){
Image($r('app.media.startIcon'))
.width(200)
Text('耐克龙年限定款!!!')
.fontSize(20)
.width(200)
Row(){
Image($r('app.media.startIcon'))
.width(20)
Text(' 令人脱发的代码')
}.width(200)
}
data:image/s3,"s3://crabby-images/342bb/342bb3aea5fdd8534d94da68987ec0e4c3f340d5" alt=""
输入框与按钮
data:image/s3,"s3://crabby-images/313f0/313f0be8d2b6b7421a5a899a0bfac64163e3edaf" alt=""
ts
build() {
//控制组件间的距离,可以给Column设置{space:间隙大小}
Column({space:10}){
TextInput({
placeholder:'请输入用户名'
}).type(InputType.Normal)
TextInput({
placeholder:'请输入密码'
}).type(InputType.Password)
Button('登录')
.backgroundColor('#3575ED')
.width(200)
}
}
data:image/s3,"s3://crabby-images/47325/4732555006c8ba9e9808209a3837dcdcfbf0ec4c" alt=""
综合实训
data:image/s3,"s3://crabby-images/98cec/98cec6365e02c3c93e67067ae1daf55fd0fb2cc7" alt=""
ts
build() {
//构建界面核心思路:
//1.排版(思考布局)
//2,内容(基础组件)
//3.美化(属性方法)
Column({space:10}){
Image($r('app.media.startIcon'))
.width(50)
TextInput({
placeholder:'输入用户名'
})
TextInput({
placeholder:'请输入密码'
}).type(InputType.Password)
Button('登录')
.width('100%')
Row({space:15}){
Text('前往注册')
Text('忘记密码')
}
}.width('100%')
.padding(20)
}
设计资源-svg图标
data:image/s3,"s3://crabby-images/84451/844514fde13b3b9d6b09f036070b6ef6777e640e" alt=""
鸿蒙图标库:
https://developer.huawei.com/consumer/cn/design/harmonyos-icon/
data:image/s3,"s3://crabby-images/24f02/24f02d00bf6a31cd4ba0e3734bacec0b99c3149c" alt=""
布局元素的组成
data:image/s3,"s3://crabby-images/0b4af/0b4afcc50042192c6bde17c25b61196ae35b611a" alt=""
内边距padding
data:image/s3,"s3://crabby-images/ec3e1/ec3e1af493a672247d3281178b4cf44490c402a9" alt=""
外边距margin
data:image/s3,"s3://crabby-images/a9b0e/a9b0e4c442745d2425cfb7f1a3bf35dfc9c51d3c" alt=""
练习:
data:image/s3,"s3://crabby-images/fdcc7/fdcc79e9030dd5c2bb233c1915d1693c76d91365" alt=""
ts
//构建 → 界面
build() {
Column(){
Image($r('app.media.startIcon'))
.width(50)
.margin({
top:120
})
Text('大王叫我来巡山')
.fontSize(25)
.fontWeight(FontWeight.Bold)
.margin({
top:20,
})
Button('QQ音乐登录')
.fontColor(Color.White)
.fontWeight(FontWeight.Bold)
.backgroundColor('#387DF6')
.width('100%')
.margin({
top:80
})
Button('微信登录')
.fontColor(Color.Black)
.fontWeight(FontWeight.Bold)
.backgroundColor('#DFDFDF')
.width('100%')
.margin({
top:15
})
}.width('100%')
.padding(20)
}
边框
data:image/s3,"s3://crabby-images/cd768/cd768ac2b80d5e30e331e38a66deec22f84acec4" alt=""
ts
//构建 → 界面
build() {
Column(){
Text('四条边')
.fontColor(Color.Red)
.padding(5)
.border({
width:1,//宽度
color:Color.Red,//颜色
style:BorderStyle.Dotted//央视(实线 虚线 点线)
}).margin({
bottom:20
})
Text('单边框')
.fontColor(Color.Red)
.padding(5)
//单边框,可以通过left right top bottom配置四个方向边框
.border({
width:{
left:1,
right:3
},
color:{
left:Color.Yellow,
right:'#ff68'
},
style:{
left:BorderStyle.Solid,
right:BorderStyle.Dotted
}
})
}.width('100%')
.padding(20)
}
data:image/s3,"s3://crabby-images/e745c/e745cc213845de547f19d268f1c9dfb10ab103bb" alt=""
设置组件圆角
data:image/s3,"s3://crabby-images/d0414/d04147f8315ff1c092698004367321eb080bf8f5" alt=""
data:image/s3,"s3://crabby-images/78867/788679fe74cc6b832563730f3fd87a397272f2c6" alt=""
特殊形状圆角设置
data:image/s3,"s3://crabby-images/73995/739951979128937ef55c27f789ba60cac40db0f4" alt=""
ts
//构建 → 界面
build() {
Column(){
Text('四条边')
.fontColor(Color.Red)
.padding(5)
.border({
width:1,//宽度
color:Color.Red,//颜色
style:BorderStyle.Dotted//央视(实线 虚线 点线)
}).margin({
bottom:20
})
Text('单边框')
.fontColor(Color.Red)
.padding(5)
//单边框,可以通过left right top bottom配置四个方向边框
.border({
width:{
left:1,
right:3
},
color:{
left:Color.Yellow,
right:'#ff68'
},
style:{
left:BorderStyle.Solid,
right:BorderStyle.Dotted
}
})
//倒角
Text('倒角')
.backgroundColor(Color.Pink)
.margin(30)
.padding(10)
.borderRadius({
topLeft:10,
bottomRight:10
})
//图片
Image($r('app.media.startIcon'))
.width(100)
.height(100)
.borderRadius(50)
//正圆
Text('正圆')
.backgroundColor(Color.Pink)
.margin(30)
.padding(10)
.width(50)//宽高一样
.height(50)
.borderRadius(25)//圆角是宽或者高的一半
//胶囊
Text('胶囊')
.backgroundColor(Color.Green)
.padding(20)
.width(150)//宽比高大
.height(50)
.borderRadius(25)//圆角是高的一半
}.width('100%')
.padding(20)
}
背景图-banckgroundImage
data:image/s3,"s3://crabby-images/20985/2098576a0451cebff1d699384ec00047da9668de" alt=""
data:image/s3,"s3://crabby-images/77b90/77b9034fbef7bc3739e32714f8aed6fcf4b63719" alt=""
ts
Text('tupian')
.padding(20)
.backgroundColor(Color.Orange)
.margin(20)
.width(400)
.height(400)
.backgroundImage($r('app.media.app_icon'),ImageRepeat.XY)//图片重复,x横轴,y纵轴,xy铺满
data:image/s3,"s3://crabby-images/f2ced/f2cedc90f4eab8e4849d948b87f8de12b0747630" alt=""
背景属性
data:image/s3,"s3://crabby-images/cbde9/cbde91c552edae9789ae605f7a0ec944d98cb9fc" alt=""
ts
//构建 → 界面
build() {
//backgroundImagePosition
//1,传入对象,设置位置坐标,背景图片的左顶点
//{x:坐标值,Y:坐标值}
//注意:坐标值的单位,和宽高的默认单位不同的,显示出来大小会不同
//2,Alignment枚举,设置一些特殊的位置(中央、左顶点..)
//Center TopStart左J顶点TopEnd右顶点BottomEnd右下...
Column(){
Text()
.width(300)
.height(200)
.backgroundColor(Color.Pink)
.backgroundImage($r('app.media.startIcon'))
.backgroundImagePosition({
x:100,
y:100
})
.backgroundImagePosition(Alignment.Center)
}.width('100%')
.padding(20)
}
data:image/s3,"s3://crabby-images/49101/49101a0f2a2e8419441b2de85ca2c03b1475e681" alt=""
单位问题
data:image/s3,"s3://crabby-images/2fbfb/2fbfb2e28d8098f9f1252465cbfd904f0f0263f2" alt=""
data:image/s3,"s3://crabby-images/94451/9445127fd9a134c9d4f39583e40d8108d3957a65" alt=""
背景属性data:image/s3,"s3://crabby-images/2b61b/2b61b70f55ff984ae1f02a53978f05069ae2afce" alt=""
data:image/s3,"s3://crabby-images/f058b/f058b218cfcd1c704a92a599440aaaa637c47c81" alt=""
ts
Text()
.height(200)
.width(300)
.backgroundImage($r('app.media.huawei'))
.backgroundImageSize(ImageSize.Cover)
data:image/s3,"s3://crabby-images/08a67/08a67d07972973ee64fa39323d5a6aeaffdecaaa" alt=""
线性布局
data:image/s3,"s3://crabby-images/5d2de/5d2de171c1fd3293f86114ffa67440bd1d41d299" alt=""
data:image/s3,"s3://crabby-images/57f66/57f6661ec998615402082ebd28f8530dcd826248" alt=""
ts
//纵向布局
.build() {
Column(){
Text()
.width(200).height(100)
.backgroundColor(Color.Pink)
.borderWidth(1)
Text()
.width(200).height(100)
.backgroundColor(Color.Pink)
.borderWidth(1)
Text()
.width(200).height(100)
.backgroundColor(Color.Pink)
.borderWidth(1)
}.width('100%').height('100%')
//设置排布主方向的对齐方式(主轴)
//1.Start(排布主方向)主轴起始位置对齐
//2.Center主轴居中对齐
//3.End主轴结束位置对齐
//4.SpaceBetween贴边显示,中间的元素均匀分布间隙
//5.Space正ound间隙环绕0.5 1 1 1 0.5的间隙分布,靠边只有一半的间隙
//6,SpaceEvenly间隙均匀环绕,靠边也是完整的一份间隙
//justifyContent(枚举FlexAlign)ctrL+p cmd+p
//.justifyContent(FLexAlign.Center)
//.justifyContent(FLexAlign.SpaceBetween)
//justifyContent(FLexAlign.SpaceAround)
.justifyContent(FlexAlign.Center)
ts
//横向布局
build() {
Row(){
Text()
.width(50).height(200)
.backgroundColor(Color.Pink)
.borderWidth(1)
Text()
.width(50).height(200)
.backgroundColor(Color.Pink)
.borderWidth(1)
Text()
.width(50).height(200)
.backgroundColor(Color.Pink)
.borderWidth(1)
}.width('100%').height('100%')
//设置排布主方向的对齐方式(主轴)
//1.Start(排布主方向)主轴起始位置对齐
//2.Center主轴居中对齐
//3.End主轴结束位置对齐
//4.SpaceBetween贴边显示,中间的元素均匀分布间隙
//5.Space正ound间隙环绕0.5 1 1 1 0.5的间隙分布,靠边只有一半的间隙
//6,SpaceEvenly间隙均匀环绕,靠边也是完整的一份间隙
//justifyContent(枚举FlexAlign)ctrL+p cmd+p
//.justifyContent(FLexAlign.Center)
//.justifyContent(FLexAlign.SpaceBetween)
//justifyContent(FLexAlign.SpaceAround)
.justifyContent(FlexAlign.SpaceEvenly)
}
data:image/s3,"s3://crabby-images/d1d86/d1d860580c4cb6dba98a8ed7c411c35cc9868154" alt=""
个人中心-顶部导航栏
data:image/s3,"s3://crabby-images/001ac/001ac79c024259f4bceae907accecd81495da992" alt=""
ts
//构建 → 界面
build() {
Column(){
Row(){
Image($r('app.media.ic_public_arrow_left_filled'))
.width(30)
Text('个人中心')
.fontSize(24)
Image($r('app.media.ic_gallery_photoedit_more'))
.width(30)
}.width('100%').height(40)
.justifyContent(FlexAlign.SpaceBetween)
.padding({left:10,right:10})
.backgroundColor(Color.White)
}.width('100%').height('100%')
.backgroundColor(Color.Pink )
data:image/s3,"s3://crabby-images/02568/02568ecd8a8db90752707bfdc88d6fe408023498" alt=""
data:image/s3,"s3://crabby-images/0d620/0d620482c92377cc6d7b42c39d05022212c6c01f" alt=""
ts
//Row的交叉轴的对齐方式(垂直向下的交叉轴)
Row(){内容......}.alignItems(VerticalAlign.Top)
//Column的交叉轴的对齐方式(垂直向右的交叉轴)
Column(){内容......}.alignItems(VerticalAlign.Top)
data:image/s3,"s3://crabby-images/a4068/a4068d49416c59e8866ce5b0d95b7c61dc1204b7" alt=""
得物-列表项
data:image/s3,"s3://crabby-images/02472/024729c1acb40c4ffd6b3251d1fef64d19af2683" alt=""
ts
//构建 → 界面
build() {
Column(){
//左侧列
Row(){
Column({space:10}){
Text('玩一玩')
.fontWeight(FontWeight.Bold)
.fontSize(18)
Row(){
Text('签到兑礼')
.fontColor('#ccc')
.fontSize(12)
Text('|超多大奖')
.fontColor('#ccc')
.fontSize(12)
Text(' 超好玩')
.fontColor('#ccc')
.fontSize(12)
}
}.alignItems(HorizontalAlign.Start)
//右侧行
Row(){
Image($r('app.media.startIcon'))
.width(50)
.margin({
right:10
})
Image($r('app.media.ic_public_arrow_right_filled'))
.width(30)
.fillColor('#ccc')
}.justifyContent(FlexAlign.SpaceBetween)
}
.justifyContent(FlexAlign.SpaceBetween)
.backgroundColor(Color.White)
.width('100%')
.height(80)
.borderRadius(10)
.padding({
left:15,
right:15
})
}.width('100%').height('100%')
.padding(10)
.backgroundColor(Color.Pink)
}
data:image/s3,"s3://crabby-images/d6218/d621806c9d11078f1766568aa28f048cf05e5f45" alt=""