JAVA中的组件的pick,鸿蒙OS应用开发之——Java UI框架-常用组件DatePicker

一 概述DatePicker的使用

DatePicker样式设置

二 DatePicker的使用

2.1 在XML中创建DatePicker

布局文件1

2

3

4

5

6

7

8

9

10

11

12<?xml version="1.0" encoding="utf-8"?>

xmlns:ohos="http://schemas.huawei.com/res/ohos"

ohos:height="match_parent"

ohos:width="match_parent"

ohos:orientation="vertical">

ohos:id="$+id:date_pick"

ohos:height="match_content"

ohos:width="300vp">

效果图

c1e61a7be8d174dc13503b1d424293ce.gif

2.2 获取当前选择日期,日/月/年,DatePicker默认选择当前日期1

2

3

4

5// 获取DatePicker实例

DatePicker datePicker = (DatePicker) findComponentById(ResourceTable.Id_date_pick);

int day = datePicker.getDayOfMonth();

int month = datePicker.getMonth();

int year = datePicker.getYear();

2.3 响应日期改变事件

布局文件1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24<?xml version="1.0" encoding="utf-8"?>

xmlns:ohos="http://schemas.huawei.com/res/ohos"

ohos:height="match_parent"

ohos:width="match_parent"

ohos:orientation="vertical">

ohos:id="$+id:date_pick"

ohos:height="match_content"

ohos:width="300vp">

ohos:id="$+id:text_date"

ohos:height="match_content"

ohos:width="match_parent"

ohos:hint="date"

ohos:margin="8vp"

ohos:padding="4vp"

ohos:text_size="14fp">

在Java代码中响应日期改变事件1

2

3

4

5

6

7

8

9Text selectedDate = (Text) findComponentById(ResourceTable.Id_text_date);

datePicker.setValueChangedListener(

new DatePicker.ValueChangedListener() {

@Override

public void onValueChanged(DatePicker datePicker, int year, int monthOfYear, int dayOfMonth) {

selectedDate.setText(dayOfMonth+"/"+monthOfYear+"/"+year);

}

}

);

日期改变响应效果

30f9acfc026eaec9256443ca76d2d78b.gif

2.4 设置当前日期1datePicker.updateDate(2021, 8, 8);

2.5 设置日期的范围

如需对DatePicker的日期选择范围有要求,可以设置属性min_date和max_date。设置的值为日期对应的Unix时间戳

2.5.1 设置最小日期

在xml设置

1

2

3

4

...

ohos:min_date="1627747200">

在代码中设置

1datePicker.setMinDate(1627747200);

设置最小日期为2021/08/01

5f6fc71dadc03cf574059e1030a62d3a.gif

2.5.2 设置最大日期

在XML中设置

1

2

3

4

...

ohos:max_date="1630339200">

在代码中设置

1datePicker.setMaxDate(1630339200);

设置最大日期为2021/08/31

ea2190111667c32891f5a76f26c3753d.gif

2.6 固定年/月/日

固定年/月/日属性

描述

year_fixed

年份固定,默认false

month_fixed

月份固定,默认false

day_fixed

日期固定,默认false

在XML中设置1

2

3

4

...

ohos:year_fixed="true">

在代码中设置1datePicker.setYearFixed(true);

三 样式设置

3.1 文本相关属性属性

Java方法

描述

normal_text_color

setNormalTextColor(int color)

待选项的字体颜色

normal_text_size

setNormalTextSize(int size)

待选项的字体大小

operated_text_color

setOperatedTextColor(int color)

操作项的字体颜色

operated_text_background

setOperatedTextBackground(Element element)

操作项的文本背景

selected_text_color

setSelectedTextColor(int color)

已选项的字体颜色

selected_text_size

setSelectedTextSize(int size)

已选项的字体大小

selected_text_background

setSelectedTextBackground(Element element)

已选项的文本背景

3.1.1 设置待选项的字体大小和颜色

在XML中设置

1

2

3

4

5

...

ohos:normal_text_color="#00FFFF"

ohos:normal_text_size="20fp">

效果图

960a8f121f935b839c06a850a6610a91.gif

3.1.2 设置已选项的字体大小和颜色

在XML中设置

1

2

3

4

5

...

ohos:selected_text_color="#00FFFF"

ohos:selected_text_size="20fp">

在代码中设置

1

2datePicker.setSelectedTextSize(40);

datePicker.setSelectedTextColor(new Color(Color.getIntColor("#FFA500")));

效果图

7ed92e0ce2802a028e1befd586548e30.gif

3.1.3 设置操作项的字体颜色

在XML中设置

1

2

3

4

...

ohos:operated_text_color="#00FFFF">

在代码中设置

1datePicker.setOperatedTextColor(new Color(Color.getIntColor("#00FFFF")));

效果图

9835b208b39b9f39e6a9822d360b109f.gif

3.2 设置DatePicker中所选文本边距与普通文本边距的比例

在XML中设置1

2

3

4

...

ohos:selected_normal_text_margin_ratio="10">

在代码中设置1datePicker.setSelectedNormalTextMarginRatio(10.0f)

效果图

9835b208b39b9f39e6a9822d360b109f.gif

3.3 设置滚轮绕行

在XML中设置:1

2

3

4

...

ohos:wheel_mode_enabled="true">

在代码中设置1datePicker.setWheelModeEnabled(true);

效果图

3144ebe115d6818abfef79c5c134d4b9.gif

3.4 设置选中日期的上下边框

在XML中设置1

2

3

4

5

...

ohos:top_line_element="#9370DB"

ohos:bottom_line_element="#9370DB">

在代码中设置1

2

3

4ShapeElement shape = new ShapeElement();

shape.setShape(ShapeElement.RECTANGLE);

shape.setRgbColor(RgbColor.fromArgbInt(0xFF9370DB));

datePicker.setDisplayedLinesElements(shape,shape);

效果图

ca68b4140635e325f4dd9e8a4a238ecd.gif

3.5 设置着色器颜色

在XML中设置1

2

3

4

...

ohos:shader_color="gray">

在代码中设置1datePicker.setShaderColor(new Color(Color.getIntColor("#00CED1")));

效果图

fc8c8a28508f64e5a5ff9a8283cdfde6.gif

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值