鸿蒙App开发,最牛输入框TextField火力全开!

2023-12-02 14:50

本文主要是介绍鸿蒙App开发,最牛输入框TextField火力全开!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

​一、新增API

实际项目开发中,输入框展示的效果通常会设计为底部一根带有颜色的线条,安卓中实现要么自定义背景,要么自定义控件,相对较麻烦。

鸿蒙对此做了优化,提供了一个属性,只需要设置需要的颜色即可实现该效果。

别看这一点功能很小,但可以看得出华为是用心在做鸿蒙系统,对开发者是真的福音!

 

Xml用法

ohos:basement="#FF0000"

Java用法

// 创建颜色shapeElement对象
ShapeElement shapeElement = new ShapeElement();
shapeElement.setRgbColor(new RgbColor(0xFF0000FF));
// 设置
textField.setBasement(shapeElement);

效果如下图:

下面演示另一种背景实现方法:

 

先看效果图:

 

 

代码如下:

// 定义背景shape文件:text_field_bg.xml
<?xml version="1.0" encoding="utf-8"?>
<shapexmlns:ohos="http://schemas.huawei.com/res/ohos"ohos:shape="rectangle">
​<cornersohos:radius="30vp"/><solidohos:color="#FFEBEBEB"/>
</shape>
// 布局文件中引用
<TextFieldohos:id="$+id:tf"ohos:height="60vp"ohos:width="match_parent"ohos:text_alignment="vertical_center"ohos:left_padding="20vp"ohos:right_padding="20vp"ohos:text_size="30vp"ohos:background_element="$graphic:text_field_bg"/>

 


 

二、优化API

 

1、优化内容监听功能

 

与安卓相比,TextField文本内容更新监听做了精简优化,从3个回调监听变成了1个。

 

Text.TextObserver:文本内容更新观察者

 

该观察者为一个interface接口,需要重写onTextUpdated方法,该方法有4个参数:

参数1,String content:这次更新后,输入框文本内容字符串。

参数2,int start:这次更新前,文本内容的起始位置。

参数3,int before:这次更新前,文本内容长度。

参数4,int count:这次更新的文本内容与更新前文本内容对比,变化的长度。

 

监听变化代码如下:

TextField textField = (TextField) findComponentById(ResourceTable.Id_tf);
Text.TextObserver textUpdateObserver = new Text.TextObserver() {@Overridepublic void onTextUpdated(String content, int start, int before, int count) {// content:这次更新后,输入框文本内容字符串// start:这次更新前,文本内容的起始位置// before:这次更新前,文本内容长度// count:这次更新的文本内容与更新前文本内容对比,变化的长度}
};
// 添加观察者
textField.addTextObserver(textUpdateObserver);
// 移除观察者
textField.removeTextObserver(textUpdateObserver);

 

2、优化文本选择器相关API

 

在安卓系统中,长按文本选择后会弹出剪切复制等的文本选择器,如下图效果:

 

 

安卓产品经理:明天你适配下所有机型,将文本选择器改成可配置的颜色!

安卓程序员:……

安卓程序员:mmp!

安卓并未提供相关API,只能通过主题和反射去修改,但效果极差,许多手机还不生效。

 

现在鸿蒙优化了,喜大普奔啊!

 

1、 设置选中区域颜色

 

Xml用法

// 设置十六进制颜色值
ohos:selection_color="#0000FF"
// 或,使用颜色引用
ohos:selection_color="$color:blue"

Java用法

textField.setSelectionColor(Color color)

 

使用蓝色,效果如下图:

 

 


 

2、 设置气泡尺寸

 

Xml用法

 

设置光标下气泡尺寸:

// 气泡宽度
ohos:bubble_width="100vp"
// 气泡高度
ohos:bubble_height="50vp"

 

设置选中文本左右两边气泡尺寸:

// 设置左边气泡尺寸
ohos:bubble_left_width="50vp"
ohos:bubble_left_height="100vp"
// 设置右边气泡尺寸
ohos:bubble_right_width="20vp"
ohos:bubble_right_height="50vp"

 

Java用法

 

设置光标下气泡尺寸:

// 单独设置宽高
textField.setBubbleWidth(int width);
textField.setBubbleHeight(int height);
// 一起设置
textField.setBubbleSize(int width, int height);

 

设置选中文本左右两边气泡尺寸:

// 设置左边气泡尺寸
textField.setLeftBubbleWidth(int width);
textField.setLeftBubbleHeight(int height);
textField.setLeftBubbleSize(int width, int height);
// 设置右边气泡尺寸
textField.setRightBubbleWidth(int width);
textField.setRightBubbleHeight(int height);
textField.setRightBubbleSize(int width, int height);

 

效果如下图:

 

2、 设置气泡背景图

 

Xml用法

 

设置光标下的气泡背景(可以是媒体资源图片,如png、jpg,也可以是shape设置颜色背景),这里只使用媒体图片举例:

ohos:element_cursor_bubble="$media:icon"

 

设置选中文本左右两边气泡背景(可以是媒体资源图片,如png、jpg,也可以是shape设置颜色背景),这里只使用媒体图片举例:

// 左边气泡图片
ohos:element_selection_left_bubble="$media:icon"
// 右边气泡图片
ohos:element_selection_right_bubble="$media:icon"

 

Java用法

 

设置光标下的气泡背景,与xml一样只举例媒体图片:

TextField textField = (TextField) findComponentById(ResourceTable.Id_text_helloworld);
Resource resource = getResourceManager().getResource(ResourceTable.Media_icon);
PixelMapElement pixelMapElement = new PixelMapElement(resource);
// 设置图片气泡
textField.setBubbleElement(pixelMapElement);

 

设置选中文本左右两边气泡背景,与xml一样只举例媒体图片:

TextField textField = (TextField) findComponentById(ResourceTable.Id_text_helloworld);
Resource resource = getResourceManager().getResource(ResourceTable.Media_icon);
PixelMapElement pixelMapElement = new PixelMapElement(resource);
// 设置左边气泡
textField.setSelectionLeftBubbleElement(pixelMapElement);
// 设置右边气泡
textField.setSelectionRightBubbleElement(pixelMapElement);

 

效果如下图:

 

 

三、常规API

 

其他常用API与安卓类似, 下面列举一些介绍。

 

1、 设置输入框弹出键盘类型

 

鸿蒙对输入类型做了精简,只提供了4中枚举类型,这里特别要提的是,鸿蒙提供了一种新的枚举类型:pattern_null,设置后,输入框获取焦点不会弹出键盘,,具体可以下面用法。

 

Xml用法

// 设置后,输入框获取到焦点,不弹出键盘
ohos:text_input_type="pattern_null"
// 文本类型键盘
ohos:text_input_type="pattern_text"
// 密码类型键盘,输入框变成了*号密码类型
ohos:text_input_type="pattern_password"
// 数字类型键盘
ohos:text_input_type="pattern_number"

 

Java用法

// 设置后,输入框获取到焦点,不弹出键盘
textField.setTextInputType(InputAttribute.PATTERN_NULL);
// 文本类型键盘
textField.setTextInputType(InputAttribute.PATTERN_TEXT);
// 密码类型键盘,输入框变成了*号密码类型
textField.setTextInputType(InputAttribute.PATTERN_PASSWORD);
// 数字类型键盘
textField.setTextInputType(InputAttribute.PATTERN_NUMBER);

 

2、 设置输入框弹出键盘类型

 

很遗憾,作者本以为会有该功能,但……

 

可是我找到了TextFilter类啊!TextField却没有与之关联的方法,由于鸿蒙目前没有开放Java源代码,无法查看,所以……

 

 

应该是提交代码的时候忘记了……或者是……git的锅!

 

安卓提供了属性android:digits和java方法setFilters,用来限制输入框只能输入自己限定的字符,这个功能很常用,目前看来只能通过上面提到的TextObserver监听去控制。

 

3、 其他常用API

 

(1)获取输入框内容:

 

textField.getText()textField.getEditableString()

 

(2)设置占位文本:

 

Xml用法

// hint内容ohos:hint="HarmonyOS"// hint颜色ohos:hint_color="#0000FF"

Java用法

// hint内容textField.setHint("HarmonyOS");// hint颜色textField.setHintColor(Color.RED);

 

(3)设置占位文本:

 

Xml用法

// 使用垂直居中,也可以使用其他对其属性ohos:text_alignment="vertical_center"

 

Java用法

// 使用垂直居中,也可以使用其他对其属性textField.setTextAlignment(TextAlignment.VERTICAL_CENTER);

 

其他的如:设置行高、行距,字间距等这些功能就不再演示,与安卓一样。

这篇关于鸿蒙App开发,最牛输入框TextField火力全开!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/445745

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

基于Python开发PPTX压缩工具

《基于Python开发PPTX压缩工具》在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,不便于传输和存储,所以本文将使用Python开发一个PPTX压缩工具,需要的可以了解下... 目录引言全部代码环境准备代码结构代码实现运行结果引言在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

macOS怎么轻松更换App图标? Mac电脑图标更换指南

《macOS怎么轻松更换App图标?Mac电脑图标更换指南》想要给你的Mac电脑按照自己的喜好来更换App图标?其实非常简单,只需要两步就能搞定,下面我来详细讲解一下... 虽然 MACOS 的个性化定制选项已经「缩水」,不如早期版本那么丰富,www.chinasem.cn但我们仍然可以按照自己的喜好来更换

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

你的华为手机升级了吗? 鸿蒙NEXT多连推5.0.123版本变化颇多

《你的华为手机升级了吗?鸿蒙NEXT多连推5.0.123版本变化颇多》现在的手机系统更新可不仅仅是修修补补那么简单了,华为手机的鸿蒙系统最近可是动作频频,给用户们带来了不少惊喜... 为了让用户的使用体验变得很好,华为手机不仅发布了一系列给力的新机,还在操作系统方面进行了疯狂的发力。尤其是近期,不仅鸿蒙O