鸿蒙UI系统组件16——富文本编辑器(RichEditor)

如果你也对鸿蒙开发感兴趣,加入“Harmony自习室”吧!扫描下方名片,关注公众号,公众号更新更快,同时也有更多学习资料和技术讨论群。

鸿蒙UI系统组件16——富文本编辑器(RichEditor)_第1张图片

RichEditor是支持图文混排和文本交互式编辑的组件,通常用于响应用户的对于图文混合内容的输入操作,例如可以输入图片的评论区。下面针对RichEditor的基本使用做一个讨论。

创建一个RichEditor组件

创建一个RichEditor组件的方式有两种:a)不使用属性字符串构建RichEditor组件;b)使用属性字符串构建RichEditor。

⭐️ 不使用属性字符串构建方式接口定义如下:

RichEditor(value: RichEditorOptions)

RichEditorOptions的类图一览如下:

鸿蒙UI系统组件16——富文本编辑器(RichEditor)_第2张图片

其中RichEditorOptions是富文本组件初始化选项。示例代码如下:

controller: RichEditorController = new RichEditorController();options: RichEditorOptions = { controller: this.controller };RichEditor(this.options)    .onReady(() => {
  
          this.controller.addTextSpan('创建不使用属性字符串构建的RichEditor组件。', {
  
              style: {
  
                  fontColor: Color.Black,                fontSize: 15            }        })    })

示例代码对应的效果如下:

鸿蒙UI系统组件16——富文本编辑器(RichEditor)_第3张图片

⭐️ 使用属性字符串构建方式接口定义如下:

RichEditor(options: RichEditorStyledStringOptions)

RichEditorStyledStringOptions的类图一览如下:

鸿蒙UI系统组件16——富文本编辑器(RichEditor)_第4张图片

其中RichEditorStyledStringOptions是富文本组件初始化选项。示例代码如下:

mutableStyledString: MutableStyledString = new MutableStyledString("创建使用属性字符串构建的RichEditor组件。",    [{
  
          start: 0,        length: 5,        styledKey: StyledStringKey.FONT,        styledValue: this.fontStyle    }]);controller: RichEditorStyledStringController = new RichEditorStyledStringController();options: RichEditorStyledStringOptions = {controller: this.controller};RichEditor(this.options)    .onReady(() => {
  
          this.controller.setStyledString(this.mutableStyledString);    })

实例代码对应的效果如下:

鸿蒙UI系统组件16——富文本编辑器(RichEditor)_第5张图片

为RichEditor设置属性

⭐️ 设置自定义选择菜单

通过bindSelectionMenu设置自定义选择菜单,接口定义为:

bindSelectionMenu(  spanType: RichEditorSpanType,   content: CustomBuilder,   responseType: ResponseType | RichEditorResponseType,  options?: SelectionMenuOptions)// 涉及到的核心数据结构如下enum RichEditorSpanType {
  
    TEXT = 0,  // Span为文字类型。  IMAGE = 1,  // Span为图像类型。  MIXED = 2,  // Span为图文混合类型。  BUILDER = 3,  // Span为BuilderSpan类型。}enum RichEditorResponseType{
  
    LONG_PRESS  // 通过长按触发菜单弹出。  RIGHT_CLICK  // 通过鼠标右键触发菜单弹出。  SELECT  // 通过鼠标选中触发菜单弹出。}interface SelectionMenuOptions {
  
  onAppear: MenuOnAppearCallback  //自定义选择菜单弹出时回调。onDisappear: Callback  //自定义选择菜单关闭时回调。}type MenuOnAppearCallback = (start: number, end: number) => void

其中:

    • spanType是菜单的类型,默认值为文字类型;

    • content是菜单的内容;

    • responseType是菜单的响应类型,默认类型为长按;

    • options是菜单的选项,可设置自定义选择菜单弹出或关闭时的回调。

(自定义菜单超长时,建议内部嵌套Scroll组件使用,避免键盘被遮挡)示例代码如下:​​​​​​​

RichEditor(this.options)    .onReady(() => {
  
          this.controller.addTextSpan('组件设置了自定义菜单,长按可触发。', {
  
              style: {
  
                  fontColor: Color.Black,                fontSize: 18            }        })    })    .bindSelectionMenu(RichEditorSpanType.TEXT, this.SystemMenu, ResponseType.LongPress, {
  
          onDisappear: () => {
  
              this.sliderShow = false        }    })    .width(300)    .height(300)@BuilderSystemMenu() {
  
      Column() {
  
              Menu() {
  
                      if (this.controller) {
  
                          MenuItemGroup() {
  
                              MenuItem({
  
                

你可能感兴趣的:(鸿蒙UI系统组件16——富文本编辑器(RichEditor))