harmonyos中 提供了 各种不同功能的通知 来满足我们不同的业务需求
本文呢 我们先来看 最基本的通知 它的场景和使用方式
最基本的 是 当应用被切入后台 而应用内部发生了一些变化 就可以用通知的方式 来提醒用户
就比如 我们微信 被切到了后台 而这时 别人发消息过来了
那么 通知栏 就会出现提示 让我们快去处理
也非常简单 调harmonyos提供的通知接口就OK了
首先 我们要在需要使用的地方 导入对应的包
import notificationManager from "@ohos.notificationManager"
这时一个 harmonyos 内置的工具
直接导入就好 不需要安装
然后 它的基础语法是
let request: notificationManager.NotificationRequest = {id: 10,content: {//通知内容}
}
id的话就是一个数字 只要保证 唯一性 就OK了
content 中装的通知内容
harmonyos中 有四类
话不多说 直接看
我们将 首页编写代码如下
import notificationManager from "@ohos.notificationManager"
@Entry
@Component
struct Dom {@State ids:number = 0;aboutToAppear(){}build() {Column({space: 30}) {Button("发送基本文本通知").onClick(()=>{let request: notificationManager.NotificationRequest = {id: this.ids++,content:{contentType: notificationManager.ContentType.NOTIFICATION_CONTENT_BASIC_TEXT,normal:{title:'通知标题'+ this.ids,text:'通知内容详情',additionalText: '通知附加内容'}}}notificationManager.publish(request).then(()=> {console.log('发送通知成功')}).catch(reason => {console.log('发送通知失败',JSON.stringify(reason))})})}.width('100%').height('100%')}
}
这里 我们导入 @ohos.notificationManager
然后定义了一个 响应式数据 ids 主要是 避免通知id重复
然后 编写一个按钮
点击事假中 调用 notificationManager.NotificationRequest
id 用 ids ++ 这样 用于在增加 数字就不会有重复的
然后 类型 NOTIFICATION_CONTENT_BASIC_TEXT 基础文本型
标题 通知标题 拼接上 id号
然后 通知的内容 为 通知内容详情
附加 通知附加内容
我们手机开真机调试
然后 我们点击这个按钮
把手机的通知栏 往下拉 内容就出来了
然后 我们将代码修改成这样
import notificationManager from "@ohos.notificationManager"
@Entry
@Component
struct Dom {@State ids:number = 0;aboutToAppear(){}build() {Column({space: 30}) {Button("发送长文本").onClick(()=>{let request: notificationManager.NotificationRequest = {id: this.ids++,content:{contentType: notificationManager.ContentType.NOTIFICATION_CONTENT_LONG_TEXT,longText: {title:'通知标题'+ this.ids,text:'通知内容详情',additionalText: '通知附加内容',longText: '通知中的长文本,我很长,我很长,我很长,我很长,我很长,我很长,我很长',briefText:'通知概要和总结',expandedTitle:'通知展开时的标题'+this.ids}}}notificationManager.publish(request).then(()=> {console.log('发送通知成功')}).catch(reason => {console.log('发送通知失败',JSON.stringify(reason))})})}.width('100%').height('100%')}
}
长文本类型 基本的语法都还是一样的 我们直接真机运行
会发现 基本还是一样的 不过 多了一个向下的小箭头
我们点开这个箭头 就可以看到下面的具体内容
然后 代码改成这样
import notificationManager from "@ohos.notificationManager"
@Entry
@Component
struct Dom {@State ids:number = 0;aboutToAppear(){}build() {Column({space: 30}) {Button("多行文本型").onClick(()=>{let request: notificationManager.NotificationRequest = {id: this.ids++,content:{contentType: notificationManager.ContentType.NOTIFICATION_CONTENT_MULTILINE,multiLine: {title:'通知标题'+ this.ids,text:'通知内容详情',additionalText: '通知附加内容',briefText:'通知概要和总结',longTitle:'展开时的标题,我很宽,我很宽,我很宽',lines: ["第一行","第二行","第三行","第四行"]}}}notificationManager.publish(request).then(()=> {console.log('发送通知成功')}).catch(reason => {console.log('发送通知失败',JSON.stringify(reason))})})}.width('100%').height('100%')}
}
多行文本型
直接开真机调试
点击按钮后 还是这个样子 下面有一个向下箭头
然后 我们点击展开
这里 就会展示出 每一行的内容
最后一个是图片类型 那么 我们需要找一个图片放到 对应模块下的 media下面去
这里 我有个问题 图片最好用png的 好像jpg显示不出来
然后 我们将代码改成
import notificationManager from "@ohos.notificationManager"
import image from '@ohos.multimedia.image';
@Entry
@Component
struct Dom {@State ids:number = 0;pixel:PixelMap;async aboutToAppear(){let rm = getContext(this).resourceManager;//读取图片let file = await rm.getMediaContent($r("app.media.Text"));image.createImageSource(file.buffer).createPixelMap().then((value) => {this.pixel = value}).catch((reason) => {console.log('testTag','加载图片异常',JSON.stringify(reason))})}build() {Column({space: 30}) {Button("图片通知").onClick(()=>{let request: notificationManager.NotificationRequest = {id: this.ids++,content:{contentType: notificationManager.ContentType.NOTIFICATION_CONTENT_PICTURE,picture: {title:'通知标题'+ this.ids,text:'通知内容详情',additionalText: '通知附加内容',briefText:'通知概要和总结',expandedTitle:'展开后标题'+this.ids,picture: this.pixel}}}notificationManager.publish(request).then(()=> {console.log('发送通知成功')}).catch(reason => {console.log('发送通知失败',JSON.stringify(reason))})})}.width('100%').height('100%')}
}
这是个 NOTIFICATION_CONTENT_PICTURE 图片型的通知 这里 需要一个 picture参数 类型会比较特殊
PixelMap 是三种图片格式的第二种 像素图
这里 我们在 aboutToAppear 生命周期中处理这个逻辑 加载 media模块下的 Test 资源文件 就是我们刚才放进去的那个图片
然后 将它转为 PixelMap 赋值给 pixel
然后 用 pixel 做 picture参数
我们真机运行
然后 我们开真机运行
这里 可能是我手机鸿蒙版本低 目前看不到图片 大家可以试试
这里 手机鸿蒙版本不同 效果查验可能就比较大