成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

HarmonyOS - 實現消息定時提醒

系統 OpenHarmony
對于提醒類ReminderRequest的3個子類來說,ReminderRequestTimer用于倒計時提醒,ReminderRequestAlarm用于鬧鐘類提醒,ReminderRequestCalendar類用于日歷類提醒。

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??

前言

在一些應用中,需要通過時間設置提醒用戶操作,如鬧鐘,象棋步數倒計時等。

設計思路:將對時間的獲取與響應的結果拆分開,時間的獲取可以有倒計時與直接設計時間。響應結果可以是:震動,閃爍,通知欄,鈴聲。

項目涵蓋了IntetAgent,通知,以及JS FA調用PA等知識點,項目應用到了前面同事編寫的計時器組件??#夏日挑戰賽# HarmonyOS - 自定義組件之計時器??。

效果展示

如果需要展示震動和彈出效果,需要通過物理機進入通知管理,勾選橫幅通知和鎖屏通知并且修改震動為其他震動方式。

倒計時提醒如下圖:

#夏日挑戰賽# HarmonyOS - 實現消息定時提醒-開源基礎軟件社區


鬧鐘類提醒如下圖:

#夏日挑戰賽# HarmonyOS - 實現消息定時提醒-開源基礎軟件社區


實現步驟

1、聲明權限

"reqPermissions": [  {"name": "ohos.permission.PUBLISH_AGENT_REMINDER"  }]

2、構建前端頁面

前端頁面主要是獲取設置的倒計時以及設置的鬧鐘類的時間,封裝進一個對象ActionData通過調用接口傳遞給PA處理。

主要分為兩部分:一部分是倒計時提醒界面,一部分是鬧鐘類提醒界面。

在編寫頁面的時候遇到了一個問題:由于初步編寫hml頁面,不知道如何實現input輸入框的雙向綁定,后面請教后解決:通過change事件來觸發。

hml代碼如下:

<element name="countDown" src="../countDown/countDown.hml">
</element>
<div class="container">
<!--倒計時功能區域-->
<div class="box">
<text>倒計時: {{ leftTime }} s</text>
<input type="text" id="countDown" onchange="changeCountDown"></input>
<countDown time="{{ leftTime }}">
</countDown>
<div>
<button class="button" value="設置" onclick="alarmCountdown"></button>
</div>
</div>
<!--定時功能區域-->
<div class="box">
<form>
<text>時:</text>
<input type="text" id="hour" onchange="changeHour"></input>
<text>分:</text>
<input type="text" id="minute" onchange="changeMinute"></input>
<div>
<button class="button" value="設置" onclick="alarmClock"></button>
<button class="button" value="取消" onclick="cancel"></button>
</div>
</form>
</div>
</div>

主要js代碼如下:

通過不同的命令實現不同的調用。

//雙向綁定實現
changeHour(event){
this.hour=event.value;
},
changeMinute(event){
this.minute=event.value
},
changeCountDown(event){
this.countDown=event.value
},
//鬧鐘類提醒
alarmClock:function(){
this.notification(0x1003);
},
//倒計時提醒
alarmCountdown:function(){
this.leftTime=0;//重置倒計時的讀秒
this.leftTime=this.countDown;//同步倒計時讀秒
this.notification(0x1002);
},
//取消提醒
cancel:function(){
this.notification(0x1001);
},
//初始化action數據
initAction: function (code) {
var actionData = {hour:this.hour,minute:this.minute,countDown:this.countDown};
actionData.notify = "this actionData form JS ";
var action = {};
action.bundleName = "com.chinasoft.reminder";
action.abilityName = "ReminderAbility";
action.messageCode = code;
action.data = actionData;
action.abilityType = 1;
action.syncOption = 0;
return action;
},
//調用PA接口
notification: async function(code) {
try {
var action = this.initAction(code);
var result = await FeatureAbility.callAbility(action);
this.showToast(result);
} catch (pluginError) {
console.error("startNotification : Plugin Error = " + pluginError);
}
},

3、設置ReminderRequest類

(1)設置通知插槽NotificationSlot

這里有個坑,需要手動設置手機的通知管理的通知鈴聲,打開震動才有震動效果,打開橫幅通知才有通知彈出效果。設置如下圖:

#夏日挑戰賽# HarmonyOS - 實現消息定時提醒-開源基礎軟件社區


設置通知slot需要真實的手機才有震動效果,設置呼吸燈需要手機支持呼吸燈才有效果。

/*
* 設置通知slot
* */
private NotificationSlot setSlot() {
// 1. 設置渠道信息
NotificationSlot slot = new NotificationSlot("slot_id", "slot_name", NotificationSlot.LEVEL_HIGH);
slot.setDescription("slot_description");//設置NotificationSlot的描述信息。
slot.enableBypassDnd(true);//設置是否繞過系統的免打擾模式
slot.setEnableLight(false);//設置收到通知時是否開啟呼吸燈,前提是當前硬件支持呼吸燈。
slot.setEnableVibration(true);//設置收到通知時是否使能振動。
slot.setLedLightColor(123456);
return slot;
}
// 2. 向代理服務添加渠道對象
ReminderHelper.addNotificationSlot(setSlot());

(2)創建提醒類對象

ReminderRequest分為3個子類:1.ReminderRequestTimer ,2.ReminderRequestCalendar ,3.ReminderRequestAlarm。

ReminderRequestTimer 對象創建。

用于倒計時提醒,需要傳遞進一個倒計時的秒的參數。這個數據是從前端頁面傳過來的。

ReminderRequest reminderRequestTimer = new ReminderRequestTimer(countDown);

ReminderRequestAlarm對象創建。

用于鬧鐘類提醒,需要傳遞時間數據。需要三個參數:int hour,int minute,int[] repeatDay。

ReminderRequest reminder = new ReminderRequestAlarm(hour, minute, repeatDay);

(3)設置提醒標題和內容

提醒是以通知形式來表現的。設置通知展示的標題和內容。

reminderRequestTimer.setTitle("倒計時").setContent("炸彈");      //設置標題和內容

(4)設置提醒時長屬性

提醒默認提醒一次,如果需要提醒能長時間提醒,進行如下設置:

reminder.setRingDuration(10);//設置提醒時長

(5)設置IntentAgent

需要設置BundleName和AbilityName。且AbilityName需要全類名(加上包名),才能實現頁面的跳轉。點擊提醒彈出的通知就會跳轉到對應的頁面。

reminder.setIntentAgent(BUNDLE_NAME, ABILITY_NAME);

(6)設置延時提醒,功能按鈕

延時提醒和設置延時的時間,設置延時后提醒的次數。

當提醒時會發出通知,設置延遲提醒和關閉按鈕。

reminder.setSnoozeTimes(2)     //設置延遲提醒次數
.setTimeInterval(1 * 60);//設置一分鐘,實際為5分鐘
reminder.setActionButton("延遲", ReminderRequest.ACTION_BUTTON_TYPE_SNOOZE)
.setActionButton("關閉", ReminderRequest.ACTION_BUTTON_TYPE_CLOSE);

在這里有一個坑:通過測試得,延遲提醒的最短時間為300s(5分鐘)如果設置時間小于300s則為默認的。

注意:對于倒計時提醒設置延遲提醒不起作用,只有設置提醒時長有效。

(7)發布和取消提醒

發布和取消提醒都是通過ReminderHelper這個類來完成的,取消提醒需要獲取發布提醒后返回的一個整型id來識別需要取消哪一個提醒。

int reminderId = ReminderHelper.publishReminder(reminder);//發布提醒
ReminderHelper.cancelReminder(this.reminderId);//取消提醒

總結

對于提醒類ReminderRequest的3個子類來說,ReminderRequestTimer用于倒計時提醒,ReminderRequestAlarm用于鬧鐘類提醒,ReminderRequestCalendar類用于日歷類提醒。本項目還有日歷類提醒(ReminderRequestCalendar)的功能沒有實現,通過API可以發現其與鬧鐘類提醒的功能實現大致一樣。在運用時需要注意其中的一些細節,才能正確使用。

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??。

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2013-03-11 10:11:21

Windows 8消息提醒

2009-12-14 13:42:13

Linux桌面Linux蘋果

2022-11-07 10:43:20

RocketMQConsumer場景

2022-07-01 17:14:03

消息通知鴻蒙

2019-02-25 15:44:16

開源RabbitMQSpring Clou

2021-08-04 10:22:27

鴻蒙HarmonyOS應用

2017-03-20 09:50:35

消息隊列架構消息

2011-09-05 17:40:40

MTK定時器

2019-12-26 09:38:57

GitHub工具 wxpy

2010-06-09 15:15:34

MySQL定時執行

2022-01-26 07:01:00

開源社區項目

2011-09-16 11:08:10

IOS應用易提醒

2009-10-12 14:32:40

VB.NET實現定時關

2024-11-04 16:01:01

2020-12-21 07:31:23

實現單機JDK

2024-12-27 08:24:55

2024-03-22 12:10:39

Redis消息隊列數據庫

2025-01-10 08:20:00

MQ消息架構

2020-08-26 07:17:19

通信

2022-08-19 15:09:37

微信移動應用
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲视频欧美视频 | 精品一区二区视频 | 日韩免费网| 99精品久久 | 欧美日韩在线免费观看 | 喷潮网站 | 欧美一区二区三区久久精品 | 国产伦精品一区二区三区精品视频 | 狠狠躁天天躁夜夜躁婷婷老牛影视 | 色天天综合 | 国产精品国产三级国产a | 欧美成视频 | caoporn免费在线视频 | 亚洲中国字幕 | 欧洲一区二区在线 | 狠狠久久综合 | 久久久久欧美 | 亚洲成人免费视频 | 欧洲高清转码区一二区 | 国产一区二区高清在线 | 久久午夜国产精品www忘忧草 | www国产精| 日韩视频精品 | 久久毛片| 国产精品日女人 | 色综合久久天天综合网 | 亚洲精品无 | 精品国产乱码久久久久久闺蜜 | 成年免费大片黄在线观看一级 | 日韩一区二区三区在线视频 | 午夜私人影院在线观看 | 欧美日韩高清在线观看 | a亚洲精品| 欧美日韩久| 国产精品久久久久久久久免费软件 | 黄色一级片在线播放 | 91在线视频网址 | 亚洲欧美日韩在线一区二区 | 亚洲免费在线观看 | 国产精品久久久久久久久久久久久 | 久久91精品久久久久久9鸭 |