zl程序教程

您现在的位置是:首页 >  Javascript

当前栏目

HarmonyOS实战——Clock组件的基本使用

2023-02-26 10:18:03 时间
  • 显示类组件:时钟、定时器、进度条

1. Clock时钟组件的基本使用

  • 组件说明:Text的子类,所以可以使用Text的一些属性。
  • 常用属性:

HarmonyOS实战——Clock组件的基本使用

  • 常见方法:

HarmonyOS实战——Clock组件的基本使用

(福利推荐:阿里云、腾讯云、华为云服务器最新限时优惠活动,云服务器1核2G仅88元/年、2核4G仅698元/3年,点击这里立即抢购>>>

基本用法:

  1. xml 文件布局:
    <Clock         ohos:height="match_content"         ohos:width="match_content"         ohos:text_size="30fp"     />
  • 默认把当前时间作为一个展示,而且时间是不断走动的

HarmonyOS实战——Clock组件的基本使用

  • ohos:time_zone="GMT"是默认值
  • 24小时的格式
    <Clock         ohos:height="match_content"         ohos:width="match_content"         ohos:time_zone="GMT"         ohos:mode_24_hour="yyyy年MM月dd日 HH:mm:ss"         ohos:text_size="30fp"     />

HarmonyOS实战——Clock组件的基本使用

  • 12小时的格式,Clock 组件默认是24小时制的,所以得把默认24小时制的关掉,用下面的12小时展示
  • a 表示的是上午或下午
    <Clock         ohos:height="match_content"         ohos:width="match_content"         ohos:time_zone="GMT"         ohos:mode_24_hour="false"         ohos:mode_12_hour="yyyy年MM月dd日 hh:mm:ss a"         ohos:text_size="30fp"        />
  • 运行后,发现出现了bug

HarmonyOS实战——Clock组件的基本使用

  • 因为 Clock 组件是华为刚推出的,如果用 xml 直接指定他的属性,会出现一些小bug,不过24小时是没问题,如果使用属性的方式指定12小时计算方式,就会出现如上bug,下面就可以使用Java代码的形式来实现12小时的展示。
  1. Java 代码实现:
  • 实现12小时制如下,a 表示的是上午或下午

HarmonyOS实战——Clock组件的基本使用
ability_main
HarmonyOS实战——Clock组件的基本使用

MainAbilitySlice
HarmonyOS实战——Clock组件的基本使用

    //1.找到时钟组件     Clock clock = (Clock) findComponentById(ResourceTable.Id_clock);          //2.修改时钟组件展开的方式     //默认是24小时     //如果要按照12小时进行展示,需要先把24小时展示给关闭     clock.set24HourModeEnabled(false);          //3.指定12小时的展示格式     clock.setFormatIn12HourMode("yyyy年MM月dd日 hh:mm:ss a");
  • 运行:

HarmonyOS实战——Clock组件的基本使用

  • 发现没有任何问题

2. Clock时钟案例——24小时制和12小时制之间的转换

  • 点击按钮后,上面的24小时制的时间就会变成12小时制,再次点击后,上面的展示格式就会变成24小时制

HarmonyOS实战——Clock组件的基本使用

需求:

  1. 通过点击按钮,将时钟组件中的显示方式在24小时制和12小时制之间切换

业务分析:

  1. 页面上有时钟组件和一个按钮组件
  2. 时钟组件默认是按照24小时制显示时间
  3. 点击按钮可以切换到12小时制显示时间
  4. 再次点击按钮可以切换到24小时制显示时间

布局分析:

  • 布局中文本比较多,所以可以使用换行属性:ohos:multiple_lines="true",这个属性也是Text组件的属性,Clock组件也是Text住组件的子类,所以可以直接拿过来使用

HarmonyOS实战——Clock组件的基本使用
ability_main

<?xml version="1.0" encoding="utf-8"?> <DirectionalLayout     xmlns:ohos="http://schemas.huawei.com/res/ohos"     ohos:height="match_parent"     ohos:width="match_parent"     ohos:orientation="vertical">      <Clock         ohos:id="$+id:clock"         ohos:height="match_content"         ohos:width="match_content"         ohos:multiple_lines="true"         ohos:text_size="35fp"         ohos:text_alignment="center"         ohos:mode_24_hour="yyyy年MM月dd日 HH:mm:ss"         ohos:layout_alignment="center"         />      <Button         ohos:id="$+id:but"         ohos:height="match_content"         ohos:width="match_content"         ohos:text="改为12小时制"         ohos:text_size="40fp"         ohos:background_element="#92D050"         ohos:top_margin="30vp"         ohos:layout_alignment="center"         />  </DirectionalLayout>
  • 点击按钮时,按钮里面的文本内容也要发生相应的变化,点击按钮后上面的时间制和按钮里的文本是相反的,如:默认是24小时制,点击的按钮文本内容是“改为12小时制”。时间改为12小时制后,按钮里面的文本就会变成“改为24小时制”
  • 相当于24小时制和12小时制的时间来回做个切换
  • 因为代码中要用到 clock 对象,所以得把他放到成员位置
  • 把上面Java实现展示12小时制的代码可以拿过来复用

HarmonyOS实战——Clock组件的基本使用
HarmonyOS实战——Clock组件的基本使用

  • 运行:

HarmonyOS实战——Clock组件的基本使用

  • 点击按钮后:

HarmonyOS实战——Clock组件的基本使用

  • 还有个问题就是:再次点击按钮后,上面的12小时制要变回24小时制,按钮里的内容也要变为“改为24小组制
  • onClick 方法当中要做两种方式的判断,在方法外做一个标记,类型可以使用booleanint类型,boolean类型有两个值,只能表示两个状态,为了后期的扩展,这里使用 int 类型来做标记

HarmonyOS实战——Clock组件的基本使用

  • 这个时候需要在 onClick 方法中使用 but 来改变按钮上的文本内容,所以把 but 提为成员变量

HarmonyOS实战——Clock组件的基本使用

  • 当点击了按钮执行 onClick 方法的时候,在方法中进行判断两者的状态就行了

HarmonyOS实战——Clock组件的基本使用

  • 在24小时制中,小时用 H 来表示,而且不用 a

HarmonyOS实战——Clock组件的基本使用

MainAbilitySlice

package com.xdr630.clockapplication.slice;  import com.xdr630.clockapplication.ResourceTable; import ohos.aafwk.ability.AbilitySlice; import ohos.aafwk.content.Intent; import ohos.agp.components.Button; import ohos.agp.components.Clock; import ohos.agp.components.Component;  public class MainAbilitySlice extends AbilitySlice implements Component.ClickedListener {      Clock clock;     Button but;      @Override     public void onStart(Intent intent) {         super.onStart(intent);         super.setUIContent(ResourceTable.Layout_ability_main);          //1.找到时钟组件          clock = (Clock) findComponentById(ResourceTable.Id_clock);         //找到按钮组件         but = (Button) findComponentById(ResourceTable.Id_but);          //2.给按钮添加一个单击事件         but.setClickedListener(this);        }      @Override     public void onActive() {         super.onActive();     }      @Override     public void onForeground(Intent intent) {         super.onForeground(intent);     }      //如果为 0,表示24小时制     //如果为 1,表示12小时制     int flag = 0;      @Override     public void onClick(Component component) {          if (flag == 0){             //表示当前为24小时制             //如果当前为24小时制,则修改为12小时制             //默认是24小时             //如果要按照12小时进行展示,需要先把24小时展示给关闭             clock.set24HourModeEnabled(false);              //3.指定12小时的展示格式             clock.setFormatIn12HourMode("yyyy年MM月dd日 hh:mm:ss a");             //修改按钮上的文字             but.setText("改为24小时制");             //修改标记对应的状态             flag = 1;          }else if (flag == 1){             //当前是12小时制,要改为24小时制             clock.set24HourModeEnabled(true);             //修改展示格式             clock.setFormatIn24HourMode("yyyy年MM月dd日 HH:mm:ss");             //修改按钮上的文字             but.setText("改为12小时制");             //修改标记             flag = 0;         }       } }
  • 运行:

HarmonyOS实战——Clock组件的基本使用

  • 点击按钮“改为12小时制”

HarmonyOS实战——Clock组件的基本使用

  • 再次点击按钮“改为24小时制”

HarmonyOS实战——Clock组件的基本使用

3. Clock组件扩展——指定开始运行的时间点

  • 在以后大多数用到的时间都是系统当前的时间,个别的情况是展示指定的时间
  • 在 xml 文件加上属性time,把属性值(毫秒值或时间戳)加在后面就行了

0:表示时间从时间原点 1970-01-01 08:00:00 开始计算的,标准是1970-01-01 00:00:00,中国普遍使用东八区的时间,东八区的标准时间是比世界协调时间(UTC)/格林尼治时间(GMT)快8小时,跟标准时间是有8个小时的时差
HarmonyOS实战——Clock组件的基本使用

  • 运行:

HarmonyOS实战——Clock组件的基本使用

把时间设置为指定的时间

  • 百度:时间戳

HarmonyOS实战——Clock组件的基本使用

  • 时间戳:从时间原点开始到指定的时间,在这个过程当中一共经历了多少毫秒
  • 把刚刚转换的时间戳复制到 time 属性那里

HarmonyOS实战——Clock组件的基本使用

  • 运行后,就是从自己指定的时间开始的

HarmonyOS实战——Clock组件的基本使用

HarmonyOS实战——Clock组件的基本使用


本站部分内容转载自网络,版权属于原作者所有,如有异议请联系QQ153890879修改或删除,谢谢!
转载请注明原文链接:HarmonyOS实战——Clock组件的基本使用

你还在原价购买阿里云、腾讯云、华为云、天翼云产品?那就亏大啦!现在申请成为四大品牌云厂商VIP用户,可以3折优惠价购买云服务器等云产品,并且可享四大云服务商产品终身VIP优惠价,还等什么?赶紧点击下面对应链接免费申请VIP客户吧:

1、点击这里立即申请成为腾讯云VIP客户

2、点击这里立即注册成为天翼云VIP客户

3、点击这里立即申请成为华为云VIP客户

4、点击这里立享阿里云产品终身VIP优惠价

喜欢 (0)
[[email protected]]
分享 (0)