鸿蒙开源组件——时间和日期选择器控件

jacksky
发布于 2021-8-19 11:48
浏览
0收藏

datetimepicker

项目介绍

  • 项目名称:datetimepicker
  • 所属系列:openharmony第三方组件适配移植
  • 功能:时间日期选择器自定义组件
  • 项目移植状态:主功能完成
  • 调用差异:无
  • 开发版本:sdk6,DevEco Studio2.2 Beta1
  • 基线版本:Release 0.0.2

效果演示鸿蒙开源组件——时间和日期选择器控件-鸿蒙开发者社区

安装教程

在moudle级别下的build.gradle文件中添加依赖

// 添加maven仓库
repositories {
   maven {
       url 'https://s01.oss.sonatype.org/content/repositories/snapshots/'
   }
}

// 添加依赖库
dependencies {
   implementation 'com.gitee.chinasoft_ohos:datetimepicker:0.0.1-SNAPSHOT'   
}

在sdk6,DevEco Studio2.2 Beta1下项目可直接运行 如无法运行,删除项目.gradle,.idea,build,gradle,build.gradle文件, 并依据自己的版本创建新项目,将新项目的对应文件复制到根目录下

 

使用说明

 <Button
            ohos:id="$+id:dateButton"
            ohos:width="match_content"
            ohos:height="match_content"
            ohos:background_element="#d6d6d6"
            ohos:padding="9vp"
            ohos:text_size="20fp"
            ohos:text="Select Date"
            ohos:bottom_margin="30vp"/>

        <Checkbox
            ohos:width="match_content"
            ohos:height="match_content"
            ohos:text="close on single tap minute"
            ohos:bottom_margin="30vp"
            ohos:text_size="15fp"
            ohos:id="$+id:checkBoxCloseOnSingleTapMinute"
            ohos:marked="true"/>

        <Button
            ohos:id="$+id:timeButton"
            ohos:width="match_content"
            ohos:height="match_content"
            ohos:background_element="#d6d6d6"
            ohos:padding="9vp"
            ohos:text_size="20fp"
            ohos:text="Select Time"
            ohos:bottom_margin="30vp"/>
  • Java 调用示例
               
    // step1 :
              public class SecondAbilitySlice extends AbilitySlice
                      implements DatePickerDialog.OnDateSetListener, TimePickerDialog.OnTimeSetListener
    
    // step2 :
              findComponentById(ResourceTable.Id_dateButton).setClickedListener(new Component.ClickedListener() {
                        @Override
                        public void onClick(Component component) {
                            showdate();
                        }
                    });
            
                    findComponentById(ResourceTable.Id_timeButton).setClickedListener(new Component.ClickedListener() {
                        @Override
                        public void onClick(Component component) {
                          showtime();
                        }
                    });
    // step3:
          private void showdate() {
                datePickerDialog = DatePickerDialog.newInstance(this,SecondAbilitySlice.this,
                    calendar.get(Calendar.YEAR), calendar.get(Calendar.MONTH), calendar.get(Calendar.DAY_OF_MONTH),
                    isVibrate());
                datePickerDialog.setVibrate(isVibrate());
                datePickerDialog.setYearRange(1985,2028);
                datePickerDialog.setCloseOnSingleTapDay(isCloseOnSingleTapDay());
                datePickerDialog.setOnDateSetListener(this);
                datePickerDialog.show();
            }
            
        private void showtime() {
               timePickerDialog = TimePickerDialog.newInstance((TimePickerDialog.OnTimeSetListener) this,
                   SecondAbilitySlice.this, calendar.get(Calendar.HOUR_OF_DAY),
                   calendar.get(Calendar.MINUTE), false, false);
               timePickerDialog.setVibrate(isVibrate());
               timePickerDialog.setCloseOnSingleTapMinute(isCloseOnSingleTapMinute());
               timePickerDialog.setOnTimeSetListener(this);
               timePickerDialog.show();
           }
        
    //step4: 通过onTimeSet 和 onDateSet获取设定的时间和日期数据
      public void onTimeSet(RadialPickerLayout view, int hourOfDay, int minute) {
            new ToastsUtils.Builder(getContext())
                .setToastText("new time:" + hourOfDay + "-"
                    + minute).setDuration(2000)
                .build().show();
        }
    
     public void onDateSet(DatePickerDialog datePickerDialog, int year, int month, int day) {
            new ToastsUtils.Builder(getContext())
                .setToastText("new date:"
                    + year + "-" + (month + 1) + "-" + day).setDuration(2000)
                .build().show();
        }​

测试信息

CodeCheck代码测试无异常

CloudTest代码测试无异常

病毒安全检测通过

当前版本demo功能与安卓原组件基本无差异

版本迭代

  • 0.0.1-SNAPSHOT

版权和许可信息

Copyright 2013 Flavien Laurent (DatePicker) edisonw (TimePicker)

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

 

SearchableSpinner-master.zip 598.03K 28次下载
已于2021-8-19 11:48:15修改
收藏
回复
举报
回复
    相关推荐