HarmonyOS TextArea组件是否支持自定义emoji?

目前需求为将 [emoji01] 这类型的字符串映射为自定义的表情包图片,以ImageSpan或其他方式显示在TextArea的文本框中,并且不影响其他字符的输入,类似微信的输入框和doge表情。请问有办法实现吗?

HarmonyOS
2024-10-29 11:21:56
浏览
收藏 0
回答 1
回答 1
按赞同
/
按时间
superinsect

​TextArea不支持图文混排的能力,要想使用图文混排可以通过RichEdictor去实现。具体参考文档:

https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V5/ts-basic-components-richeditor-V5

示例如下:​

@Entry  
@Component  
struct RichEditorExample {  
  controller: RichEditorController = new RichEditorController();  
  private imgs: (string | number | Resource)[] = [$r('app.media.image1'), $r('app.media.image2'), $r('app.media.image3'), 1, 2, 3, 4, 5, 6, String.fromCodePoint(0x1F600)];  
  
  // 自定义键盘组件  
  @Builder  
  CustomKeyboardBuilder() {  
    Column() {  
      Grid() {  
        ForEach(this.imgs, (item: string | number | Resource) => {  
          GridItem() {  
            if (typeof item === 'number' || typeof item === 'string') {  
              Button(item + '')  
                .width(110).onClick(() => {  
                this.controller.addTextSpan(item + '', {  
                  offset: this.controller.getCaretOffset(),  
                  style:  
                  {  
                    fontColor: Color.Orange,  
                    fontSize: 30  
                  }  
                })  
                this.controller.setCaretOffset(this.controller.getCaretOffset() + item.toString().length)  
              })  
            } else {  
              Image(item)  
                .width(110).onClick(() => {  
                this.controller.addImageSpan(item, {  
                  imageStyle:  
                  {  
                    size: ['110px', '110px']  
                  }  
                })  
              })  
            }  
          }  
        })  
      }.maxCount(3).columnsGap(10).rowsGap(10).padding(5)  
    }.backgroundColor(Color.Gray)  
  }  
  build() {  
    Column() {  
      RichEditor({ controller: this.controller })// 绑定自定义键盘  
        .customKeyboard(this.CustomKeyboardBuilder())  
        .margin(10)  
        .border({ width: 1 })  
        .height(200)  
        .borderWidth(1)  
        .borderColor(Color.Red)  
        .width('100%')  
    }  
  }  
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
  • 48.
  • 49.
  • 50.
  • 51.
  • 52.
  • 53.
  • 54.
  • 55.
分享
微博
QQ
微信
回复
2024-10-29 17:29:54


相关问题
HarmonyOS 组件是否支持自定义事件
798浏览 • 1回复 待解决
自定义组件是否支持renderFit属性
2587浏览 • 1回复 待解决
Grid组件的scrollBar是否支持自定义
3074浏览 • 1回复 待解决
是否支持自定义装饰器
2846浏览 • 1回复 待解决
HarmonyOS ArkTS是否支持自定义注解
918浏览 • 1回复 待解决
HarmonyOS 是否支持自定义装饰器?
983浏览 • 1回复 待解决
HarmonyOS 是否支持自定义升级弹窗
670浏览 • 1回复 待解决
HarmonyOS ArkWeb是否支持自定义UserAgent
1175浏览 • 1回复 待解决
ArkTS是否支持自定义装饰器?
3517浏览 • 1回复 待解决
HarmonyOS 自定义组件支持链式调用吗
645浏览 • 1回复 待解决
弹窗打开、关闭动画是否支持自定义
3316浏览 • 1回复 待解决
ArkUI是否支持emoji表情输入
2762浏览 • 1回复 待解决
HarmonyOS 是否支持自定义内存分配器
1087浏览 • 1回复 待解决
HarmonyOS 定义自定义组件
1027浏览 • 1回复 待解决
华为手机是否支持自定义锁屏页面?
4883浏览 • 1回复 待解决
提问
该提问已有2人参与 ,帮助了18人