自学记录鸿蒙API 13:Calendar Kit日历功能从学习到实践

简介: 本文介绍了使用HarmonyOS的Calendar Kit开发日程管理应用的过程。通过API 13版本,不仅实现了创建、查询、更新和删除日程等基础功能,还深入探索了权限请求、日历配置、事件添加及查询筛选等功能。实战项目中,开发了一个智能日程管理工具,具备可视化管理、模糊查询和智能提醒等特性。最终,作者总结了模块化开发的优势,并展望了未来加入语音助手和AI推荐功能的计划。

这次的目标是学习和使用HarmonyOS的Calendar Kit功能,特别是最新的API 13版本。Calendar Kit让我感受到了一种与传统开发完全不同的体验——它提供的不只是简单的日历功能,而是一套集创建、查询、更新、删除等强大能力于一体的日程管理服务。

一开始,我仅仅是希望开发一个能够管理日常工作和个人事务的小工具。但随着学习的深入,我意识到这个模块的潜力远远超出了我的预期。于是,带着对HarmonyOS的浓厚兴趣,我决定通过实际开发一个完整的日程管理应用,将理论和实践结合起来,全面探索Calendar Kit的功能。


第一部分:构建基础——获取日历管理器

每个优秀的应用都有一个强大的核心,在Calendar Kit中,这个核心就是CalendarManager。它是我们与日历和日程打交道的桥梁。通过它,我们可以完成从创建日历到操作日程的一切功能。

在开始之前,我们需要请求用户权限,因为日历涉及隐私信息,需要
ohos.permission.READ_CALENDAR和ohos.permission.WRITE_CALENDAR权限。

代码实现:初始化CalendarManager

以下是获取CalendarManager对象的代码实现:

import { calendarManager } from '@kit.CalendarKit';
import { Permissions, abilityAccessCtrl, common } from '@kit.AbilityKit';
import { BusinessError } from '@kit.BasicServicesKit';
let calendarMgr: calendarManager.CalendarManager | null = null;
let mContext: common.UIAbilityContext | null = null;
async function initializeCalendarManager() {
    try {
        const permissions = ['ohos.permission.READ_CALENDAR', 'ohos.permission.WRITE_CALENDAR'];
        const atManager = abilityAccessCtrl.createAtManager();
        await atManager.requestPermissionsFromUser(mContext, permissions);
        console.info('权限请求成功');
        calendarMgr = calendarManager.getCalendarManager(mContext);
        console.info('CalendarManager 初始化成功');
    } catch (error) {
        console.error('初始化失败:', error);
    }
}

我的思考

权限请求是开发中的第一步,也是与用户交互的重要环节。通过清晰的提示,让用户理解为何需要这些权限,既能提升用户体验,也有助于合规开发。


第二部分:管理日历——从创建到配置

在获得CalendarManager对象后,我们可以通过它创建和管理多个日历。一个日历是管理日程的容器,因此,为不同的用途创建独立的日历是非常有必要的。

代码实现:创建日历

以下代码展示了如何使用createCalendar方法创建一个日历:

const calendarAccount: calendarManager.CalendarAccount = {
    name: 'MyWorkCalendar',
    type: calendarManager.CalendarType.LOCAL,
    displayName: '工作日历'
};
async function createCalendar() {
    try {
        const calendar = await calendarMgr?.createCalendar(calendarAccount);
        console.info(`日历创建成功: ${JSON.stringify(calendar)}`);
        return calendar;
    } catch (error) {
        console.error('创建日历失败:', error);
    }
}

配置日历

创建日历后,我们可以通过setConfig方法为其添加配置,例如是否启用提醒、设置颜色等:

const calendarConfig: calendarManager.CalendarConfig = {
    enableReminder: true,
    color: '#FF5733'
};
async function configureCalendar(calendar: calendarManager.Calendar) {
    try {
        await calendar.setConfig(calendarConfig);
        console.info('日历配置成功');
    } catch (error) {
        console.error('配置日历失败:', error);
    }
}

我的思考

我特别喜欢通过颜色区分不同的日历类型。比如,为工作日历设置红色,为个人日历设置蓝色,这种视觉化的管理方式让信息一目了然。


第三部分:日程管理——让生活井井有条

有了日历后,我们可以通过它添加日程。addEvent方法让我们能够轻松地创建一个事件,并为其添加标题、时间、描述等信息。

代码实现:添加日程

以下代码展示了如何向日历中添加一个会议事件:

const event: calendarManager.Event = {
    title: '团队会议',
    type: calendarManager.EventType.NORMAL,
    startTime: Date.now() + 60 * 60 * 1000, // 1小时后
    endTime: Date.now() + 2 * 60 * 60 * 1000, // 2小时后
    location: { location: '会议室1', latitude: 0, longitude: 0 },
    description: '讨论项目进展',
    reminderTime: [10] // 提前10分钟提醒
};
async function addEvent(calendar: calendarManager.Calendar) {
    try {
        const eventId = await calendar.addEvent(event);
        console.info(`日程添加成功,ID: ${eventId}`);
    } catch (error) {
        console.error('添加日程失败:', error);
    }
}

第四部分:查询与筛选——精准管理日程

当日程变得越来越多时,查询和筛选就显得尤为重要。Calendar Kit 提供了丰富的查询功能,比如通过标题、时间或ID来筛选事件。

代码实现:按标题查询

以下代码展示了如何通过标题模糊查询日程:

async function getEventsByTitle(calendar: calendarManager.Calendar, title: string) {
    try {
        const filter = calendarManager.EventFilter.filterByTitle(title);
        const events = await calendar.getEvents(filter);
        console.info(`查询到的日程: ${JSON.stringify(events)}`);
    } catch (error) {
        console.error('查询日程失败:', error);
    }
}

我的思考

模糊查询非常适合快速定位某类任务。例如,搜索“会议”可以找到所有与会议相关的日程,这在实际应用中极具实用价值。


第五部分:实战项目——智能日程管理工具

基于以上功能,我开发了一个智能日程管理应用。用户可以通过简洁的界面添加、查看和管理日程。

功能展示:创建新日程的UI组件

@Entry
@Component
struct CreateEventPage {
    @State title: string = '';
    @State description: string = '';
    @State startTime: string = '';
    @State endTime: string = '';
    build() {
        Column() {
            TextField({ text: this.title, placeholder: '请输入标题' })
                .onChange((value: string) => this.title = value);
            TextField({ text: this.description, placeholder: '请输入描述' })
                .onChange((value: string) => this.description = value);
            TextField({ text: this.startTime, placeholder: '开始时间 (YYYY-MM-DD HH:MM)' })
                .onChange((value: string) => this.startTime = value);
            TextField({ text: this.endTime, placeholder: '结束时间 (YYYY-MM-DD HH:MM)' })
                .onChange((value: string) => this.endTime = value);
            Button('创建日程')
                .onClick(async () => {
                    await addEvent({
                        title: this.title,
                        description: this.description,
                        startTime: new Date(this.startTime).getTime(),
                        endTime: new Date(this.endTime).getTime()
                    });
                });
        }
    }
}

智能化亮点

  • 可视化管理:通过颜色和图标区分不同类型的日历和事件。
  • 模糊查询:支持按标题或时间快速搜索。
  • 智能提醒:根据用户设置的时间提前提醒重要任务。

总结:我的收获与展望

在这次学习和实践中,我不仅熟悉了HarmonyOS Calendar Kit的强大功能,还深刻体会到模块化开发的便捷与高效。它让我能够快速构建出一套功能完善的日程管理应用,满足不同用户的需求。

接下来,我计划整合语音助手功能,实现语音创建日程;同时,加入通知服务和AI推荐,让应用更智能、更贴近用户需求。

当然如果你也在这一领域研究,不妨关注我,我们一起进步~!

目录
相关文章
|
17天前
|
缓存 API 数据安全/隐私保护
自学记录:学习HarmonyOS Location Kit构建智能定位服务
作为一名对新技术充满好奇心的开发者,我选择了HarmonyOS Next 5.0.1(API 13)作为挑战对象,深入研究其强大的定位服务API——Location Kit。从权限管理、获取当前位置、逆地理编码到地理围栏,最终成功开发了一款智能定位应用。本文将结合代码和开发过程,详细讲解如何实现这些功能,并分享遇到的挫折与兴奋时刻。希望通过我的经验,能帮助其他开发者快速上手HarmonyOS开发,共同探索更多可能性。
104 5
|
19天前
|
编解码 人工智能 缓存
自学记录鸿蒙API 13:实现多目标识别Object Detection
多目标识别技术广泛应用于动物识别、智能相册分类和工业检测等领域。本文通过学习HarmonyOS的Object Detection API(API 13),详细介绍了如何实现一个多目标识别应用,涵盖从项目初始化、核心功能实现到用户界面设计的全过程。重点探讨了目标类别识别、边界框生成、高精度置信度等关键功能,并分享了性能优化与功能扩展的经验。最后,作者总结了学习心得,并展望了未来结合语音助手等创新应用的可能性。如果你对多目标识别感兴趣,不妨从基础功能开始,逐步实现自己的创意。
188 60
|
17天前
|
API 开发者 UED
自学记录鸿蒙API 13:PreviewKit从文件预览到应用开发
通过学习API 13,我深入研究了**PreviewKit(文件预览服务)**。该模块支持快速预览多种文件类型(文本、图片、视频、音频、PDF等),为文件管理类应用提供系统级支持。本文分享了从搭建开发环境到实现单文件和多文件预览的全过程,并介绍了如何构建一个实用的文件预览助手应用。通过实践,不仅掌握了技术细节,还提升了个人开发能力。希望这些经验能为其他开发者带来启发与帮助。
46 10
自学记录鸿蒙API 13:PreviewKit从文件预览到应用开发
|
19天前
|
存储 API
鸿蒙元服务项目实战:终结篇之备忘录搜索功能实现
开发元服务,有很多的限制性因素,比如包的大小限制,相关API限制,所以,我们在实际开发的时候,具体Api能否使用,还需要去官网查看一下,目前,针对当前这个小项目,总结了几个小问题,大家在开发的过程中可以作为参考。
鸿蒙元服务项目实战:终结篇之备忘录搜索功能实现
|
19天前
|
人工智能 监控 安全
自学记录鸿蒙 API 13:骨骼点检测应用Core Vision Skeleton Detection
骨骼点检测技术能够从图片中识别出人体的关键骨骼点位置,如头部、肩部、手肘等,广泛应用于运动健身指导、游戏交互、医疗辅助、安全监控等领域。我决定深入学习HarmonyOS Next API 13中的Skeleton Detection API,并开发一个简单的骨骼点检测应用。通过理解API核心功能、项目初始化与配置、实现检测功能、构建用户界面,以及性能优化和功能扩展,逐步实现这一技术的应用。未来计划将其应用于健身指导和智能监控领域,探索与其他AI能力的结合,开发更智能的解决方案。如果你也对骨骼点检测感兴趣,不妨一起进步!
152 9
|
6天前
|
JSON 前端开发 搜索推荐
关于商品详情 API 接口 JSON 格式返回数据解析的示例
本文介绍商品详情API接口返回的JSON数据解析。最外层为`product`对象,包含商品基本信息(如id、name、price)、分类信息(category)、图片(images)、属性(attributes)、用户评价(reviews)、库存(stock)和卖家信息(seller)。每个字段详细描述了商品的不同方面,帮助开发者准确提取和展示数据。具体结构和字段含义需结合实际业务需求和API文档理解。
|
11天前
|
JSON API 数据格式
京东商品SKU价格接口(Jd.item_get)丨京东API接口指南
京东商品SKU价格接口(Jd.item_get)是京东开放平台提供的API,用于获取商品详细信息及价格。开发者需先注册账号、申请权限并获取密钥,随后通过HTTP请求调用API,传入商品ID等参数,返回JSON格式的商品信息,包括价格、原价等。接口支持GET/POST方式,适用于Python等语言的开发环境。
63 11
|
3天前
|
Web App开发 JSON 测试技术
API测试工具集合:让接口测试更简单高效
在当今软件开发领域,接口测试工具如Postman、Apifox、Swagger等成为确保API正确性、性能和可靠性的关键。Postman全球闻名但高级功能需付费,Apifox则集成了API文档、调试、Mock与自动化测试,简化工作流并提高团队协作效率,特别适合国内用户。Swagger自动生成文档,YApi开源但功能逐渐落后,Insomnia界面简洁却缺乏团队协作支持,Paw仅限Mac系统。综合来看,Apifox是国内用户的理想选择,提供中文界面和免费高效的功能。
|
1月前
|
人工智能 自然语言处理 API
Multimodal Live API:谷歌推出新的 AI 接口,支持多模态交互和低延迟实时互动
谷歌推出的Multimodal Live API是一个支持多模态交互、低延迟实时互动的AI接口,能够处理文本、音频和视频输入,提供自然流畅的对话体验,适用于多种应用场景。
86 3
Multimodal Live API:谷歌推出新的 AI 接口,支持多模态交互和低延迟实时互动
|
22天前
|
JSON 安全 API
淘宝商品详情API接口(item get pro接口概述)
淘宝商品详情API接口旨在帮助开发者获取淘宝商品的详细信息,包括商品标题、描述、价格、库存、销量、评价等。这些信息对于电商企业而言具有极高的价值,可用于商品信息展示、市场分析、价格比较等多种应用场景。

热门文章

最新文章