赞
踩
为组件绑定弹出式菜单,弹出式菜单以垂直列表形式显示菜单项,可通过长按、点击或鼠标右键触发。
说明:
bindMenu(content: Array<MenuElement> | CustomBuilder, options?: MenuOptions)
给组件绑定菜单,点击后弹出菜单。弹出菜单项支持图标+文本排列和自定义两种功能。
系统能力: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
content | Array<MenuElement> | CustomBuilder | 是 | 配置菜单项图标和文本的数组,或者自定义组件。 |
options | MenuOptions | 否 | 配置弹出菜单的参数。 |
bindMenu(isShow: boolean, content: Array<MenuElement> | CustomBuilder, options?: MenuOptions)
给组件绑定菜单,点击后弹出菜单。弹出菜单项支持图标+文本排列和自定义两种功能。
系统能力: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
isShow11+ | boolean | 是 | 支持开发者通过状态变量控制显隐,默认值为false,menu弹窗必须等待页面全部构建才能展示,因此不能在页面构建中设置为true,否则会导致显示位置及形状错误,当前不支持双向绑定。 |
content | Array<MenuElement> | CustomBuilder | 是 | 配置菜单项图标和文本的数组,或者自定义组件。 |
options | MenuOptions | 否 | 配置弹出菜单的参数。 |
bindContextMenu(content: CustomBuilder, responseType: ResponseType, options?: ContextMenuOptions)
给组件绑定菜单,触发方式为长按或者右键点击,弹出菜单项需要自定义。
系统能力: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
content | CustomBuilder | 是 | 配置菜单项图标和文本的数组,或者自定义组件。 |
responseType | ResponseType | 是 | 菜单弹出条件,长按或者右键点击。 |
options | ContextMenuOptions | 否 | 配置弹出菜单的参数。 |
名称 | 类型 | 必填 | 描述 |
---|---|---|---|
value | ResourceStr | 是 | 菜单项文本。 |
icon10+ | ResourceStr | 否 | 菜单项图标。 |
enabled11+ | boolean | 否 | 菜单条目是否可进行交互。 默认值:true, 菜单条目可以进行交互。 |
action | () => void | 是 | 点击菜单项的事件回调。 |
名称 | 类型 | 必填 | 描述 |
---|---|---|---|
title | ResourceStr | 否 | 菜单标题。 说明: 仅在content设置为Array<MenuElement> 时生效。 |
showInSubWindow11+ | boolean | 否 | 是否在子窗口显示菜单。 默认值:false。 |
名称 | 类型 | 必填 | 描述 |
---|---|---|---|
offset | Position | 否 | 菜单弹出位置的偏移量,不会导致菜单显示超出屏幕范围。 说明: 菜单类型为相对⽗组件区域弹出时,⾃动根据菜单位置属性 (placement)将区域的宽或⾼计⼊偏移量中。 当菜单相对父组件出现在上侧时(placement设置为Placement.TopLeft,Placement.Top,Placement.TopRight),x为正值,菜单相对组件向右进行偏移,y为正值,菜单相对组件向上进行偏移。 当菜单相对父组件出现在下侧时(placement设置为Placement.BottomLeft,Placement.Bottom,Placement.BottomRight),x为正值,菜单相对组件向右进行偏移,y为正值,菜单相对组件向下进行偏移。 当菜单相对父组件出现在左侧时(placement设置为Placement.LeftTop,Placement.Left,Placement.LeftBottom),x为正值,菜单相对组件向左进行偏移,y为正值,菜单相对组件向下进行偏移。 当菜单相对父组件出现在右侧时(placement设置为Placement.RightTop,Placement.Right,Placement.RightBottom),x为正值,菜单相对组件向右进行偏移,y为正值,菜单相对组件向下进行偏移。 如果菜单调整了显示位置(与placement初始值主方向不⼀致),则偏移值 (offset) 失效。 |
placement | Placement | 否 | 菜单组件优先显示的位置,当前位置显示不下时,会自动调整位置。 说明: placement值设置为undefined、null或没有设置此选项时,按未设置placement处理,菜单跟随点击位置弹出。 |
enableArrow | boolean | 否 | 是否显示箭头。如果菜单的大小和位置不足以放置箭头时,不会显示箭头。 默认值:false, 不显示箭头。 说明: enableArrow为true时,placement未设置或者值为非法值,默认在目标物上方显示,否则按照placement的位置优先显示。当前位置显示不下时,会自动调整位置,enableArrow为undefined时,不显示箭头。 |
arrowOffset | Length | 否 | 箭头在菜单处的偏移。箭头在菜单水平方向时,偏移量为箭头至最左侧的距离,默认居中。箭头在菜单竖直方向时,偏移量为箭头至最上侧的距离,默认居中。偏移量必须合法且转换为具体数值时大于0才会生效,另外该值生效时不会导致箭头超出菜单四周的安全距离。根据配置的placement来计算是在水平还是竖直方向上偏移。 |
preview11+ | MenuPreviewMode| CustomBuilder | 否 | 长按悬浮菜单的预览内容样式,可以为目标组件的截图,也可以为用户自定义的内容。 默认值:MenuPreviewMode.NONE, 无预览内容。 说明: - 仅支持responseType为ResponseType.LongPress时触发,如果responseType为ResponseType.RightClick,则不会显示预览内容。 - 当未设置preview参数或preview参数设置为MenuPreviewMode.NONE时,enableArrow参数生效。 - 当preview参数设置为MenuPreviewMode.IMAGE或CustomBuilder时,enableArrow为true时也不显示箭头。 |
previewAnimationOptions11+ | ContextMenuAnimationOptions | 否 | 控制长按预览显示动画开始倍率和结束倍率(相对预览原图比例)。 默认值:{scale: [0.95, 1.1]}。 说明: -倍率设置参数小于等于0时,不生效。 -当前只在preview设置为MenuPreviewMode.IMAGE模式时生效。 |
onAppear | () => void | 否 | 菜单弹出时的事件回调。 |
onDisappear | () => void | 否 | 菜单消失时的事件回调。 |
aboutToAppear | () => void | 否 | 菜单显示动效前的事件回调。 |
aboutToDisappear | () => void | 否 | 菜单退出动效前的事件回调。 |
backgroundColor11+ | ResourceColor | 否 | 弹窗背板颜色。 默认值:Color.Transparent |
backgroundBlurStyle11+ | ResourceColor | 否 | 弹窗背板模糊材质。 默认值:BlurStyle.COMPONENT_ULTRA_THICK |
名称 | 类型 | 必填 | 描述 |
---|---|---|---|
scale | AnimationRange<number> | 否 | 动画开始和结束时相对预览原图缩放比例。 |
表示动画开始和结束时相对预览原图缩放比例。
系统能力:SystemCapability.ArkUI.ArkUI.Full
取值范围 | 说明 |
---|---|
[from: T, to: T] | from表示动画开始时相对预览原图缩放比例,to表示动画结束时相对预览原图缩放比例。 |
普通菜单
- // xxx.ets
- @Entry
- @Component
- struct MenuExample {
- build() {
- Column() {
- Text('click for Menu')
- }
- .width('100%')
- .margin({ top: 5 })
- .bindMenu([
- {
- value: 'Menu1',
- action: () => {
- console.info('handle Menu1 select')
- }
- },
- {
- value: 'Menu2',
- action: () => {
- console.info('handle Menu2 select')
- }
- },
- ])
- }
- }
自定义内容菜单
- @Entry
- @Component
- struct MenuExample {
- @State listData: number[] = [0, 0, 0]
-
- @Builder MenuBuilder() {
- Flex({ direction: FlexDirection.Column, justifyContent: FlexAlign.Center, alignItems: ItemAlign.Center }) {
- ForEach(this.listData, (item:number, index) => {
- Column() {
- Row() {
- Image($r("app.media.icon")).width(20).height(20).margin({ right: 5 })
- Text(`Menu${index as number + 1}`).fontSize(20)
- }
- .width('100%')
- .height(30)
- .justifyContent(FlexAlign.Center)
- .align(Alignment.Center)
- .onClick(() => {
- console.info(`Menu${index as number + 1} Clicked!`)
- })
-
- if (index != this.listData.length - 1) {
- Divider().height(10).width('80%').color('#ccc')
- }
- }.padding(5).height(40)
- })
- }.width(100)
- }
-
- build() {
- Column() {
- Text('click for menu')
- .fontSize(20)
- .margin({ top: 20 })
- .bindMenu(this.MenuBuilder)
- }
- .height('100%')
- .width('100%')
- .backgroundColor('#f0f0f0')
- }
- }
菜单(长按触发显示)
- // xxx.ets
- @Entry
- @Component
- struct ContextMenuExample {
- @Builder MenuBuilder() {
- Flex({ direction: FlexDirection.Column, justifyContent: FlexAlign.Center, alignItems: ItemAlign.Center }) {
- Text('Test menu item 1')
- .fontSize(20)
- .width(100)
- .height(50)
- .textAlign(TextAlign.Center)
- Divider().height(10)
- Text('Test menu item 2')
- .fontSize(20)
- .width(100)
- .height(50)
- .textAlign(TextAlign.Center)
- }.width(100)
- }
-
- build() {
- Column() {
- Text('LongPress for menu')
- }
- .width('100%')
- .margin({ top: 5 })
- .bindContextMenu(this.MenuBuilder, ResponseType.LongPress)
- }
- }
指向性菜单(右键触发显示)
- // xxx.ets
- @Entry
- @Component
- struct DirectiveMenuExample {
- @Builder MenuBuilder() {
- Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
- Text('Options')
- Divider().strokeWidth(2).margin(5).color('#F0F0F0')
- Text('Hide')
- Divider().strokeWidth(2).margin(5).color('#F0F0F0')
- Text('Exit')
- }
- .width(200)
- }
-
- build() {
- Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
- Column() {
- Text("DirectiveMenuExample")
- .fontSize(20)
- .width('100%')
- .height("25%")
- .backgroundColor('#F0F0F0')
- .textAlign(TextAlign.Center)
- .bindContextMenu(this.MenuBuilder, ResponseType.RightClick, {
- enableArrow: true,
- placement: Placement.Bottom
- })
- }
- }
- .width('100%')
- .height('100%')
- }
- }
长按悬浮菜单(预览内容为截图形式)
- // xxx.ets
- @Entry
- @Component
- struct Index {
- private iconStr: ResourceStr = $r("app.media.icon")
-
- @Builder
- MyMenu() {
- Menu() {
- MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
- MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
- MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
- }
- }
-
- build() {
- Column({ space: 50 }) {
- Column() {
- Column() {
- Text('preview-image')
- .width(200)
- .height(100)
- .textAlign(TextAlign.Center)
- .margin(100)
- .fontSize(30)
- .bindContextMenu(this.MyMenu, ResponseType.LongPress,
- { preview: MenuPreviewMode.IMAGE,
- previewAnimationOptions: {scale: [0.8, 1.0]},
- })
- .backgroundColor("#ff3df2f5")
- }
- }.width('100%')
- }
- }
- }
长按悬浮菜单(自定义预览内容)
- // xxx.ets
- @Entry
- @Component
- struct Index {
- private iconStr: ResourceStr = $r("app.media.icon")
-
- @Builder
- MyMenu() {
- Menu() {
- MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
- MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
- MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
- }
- }
-
- @Builder
- MyPreview() {
- Column() {
- Image($r('app.media.icon'))
- .width(200)
- .height(200)
- }
- }
-
- build() {
- Column({ space: 50 }) {
- Column() {
- Column() {
- Text('preview-builder')
- .width(200)
- .height(100)
- .textAlign(TextAlign.Center)
- .margin(100)
- .fontSize(30)
- .bindContextMenu(this.MyMenu, ResponseType.LongPress,
- {
- preview: this.MyPreview
- })
- }
- }.width('100%')
- }
- }
- }
最后,有很多小伙伴不知道学习哪些鸿蒙开发技术?不知道需要重点掌握哪些鸿蒙应用开发知识点?而且学习时频繁踩坑,最终浪费大量时间。所以有一份实用的鸿蒙(Harmony NEXT)资料用来跟着学习是非常有必要的。
这份鸿蒙(Harmony NEXT)资料包含了鸿蒙开发必掌握的核心知识要点,内容包含了(ArkTS、ArkUI开发组件、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战等等)鸿蒙(Harmony NEXT)技术知识点。
希望这一份鸿蒙学习资料能够给大家带来帮助,有需要的小伙伴自行领取,限时开源,先到先得~无套路领取!!
获取这份完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料
HarmonOS基础技能
有了路线图,怎么能没有学习资料呢,小编也准备了一份联合鸿蒙官方发布笔记整理收纳的一套系统性的鸿蒙(OpenHarmony )学习手册(共计1236页)与鸿蒙(OpenHarmony )开发入门教学视频,内容包含:ArkTS、ArkUI、Web开发、应用模型、资源分类…等知识点。
获取以上完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料
OpenHarmony北向、南向开发环境搭建
获取以上完整鸿蒙HarmonyOS学习资料,请点击→纯血版全套鸿蒙HarmonyOS学习资料
总的来说,华为鸿蒙不再兼容安卓,对中年程序员来说是一个挑战,也是一个机会。只有积极应对变化,不断学习和提升自己,他们才能在这个变革的时代中立于不败之地。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。