前言
代码运行环境:全部基于HarmonyOs NEXT
DevEco Studio:Build Version: 5.0.3.900
API:12
modelVersion:5.0.0
在之前,自定义过一个车牌省份简称的键盘,其实光有省份简称是不行的,毕竟一个正常的车牌是有省份简称+字母+数字进行组成的,索性,就再自定义一个车牌字母选择键盘,可以和之前的省份简称键盘进行结合使用。
我们先看一下最终实现的效果。
分析实现方式【代码讲解】
针对这样的一个字母加数字键盘,可以说,实现方式呢,有多种多样,我们大体可以分为三块,最上面是完成按钮,下面是一排数字按钮,再往下就是字母区域,之所以把数字和字母拆分开来,主要两个的边距是有差异的,分开来更加能容易实现;在绘制字母的时候,有一点需要注意,那就是最后的删除按钮是要占据两个格子。
数字按钮
一排数字没有什么好说的,这里使用的是Grid进行实现的,设置了10列,当然,大家也可以使用别的方式进行实现。
定义数据源
mNumberList = ["1", "2", "3", "4", "5", "6", "7", "8", "9", "0"]
代码实现
Grid() {
ForEach(this.mNumberList, (item: string, index: number) => {
GridItem() {
Text(item)
.fontSize(this.rectTextSize)
.fontColor(this.numProhibit ? this.numProhibitColor :
(this.itemSelectedArray[index] ? this.rectSelectTextColor : this.rectTextColor))
}.GridItemAttribute(this, index, item)
})
}
.height(this.rectHeight)
.columnsTemplate("1fr ".repeat(10).trimEnd())
.columnsGap(this.columnsGap)
.rowsGap(this.rowsGap)
.margin({ top: this.gridMarginTop })
.scrollBar(BarState.Off)
字母按钮
字母按钮,和数字实现是类似的,也是使用的Grid组件,有一点差异就是最后的删除按钮,需要占两格,如何进行占两格呢,主要用到了Grid组件的第二个参数layoutOptions,我们使用它来实现最后的删除按钮摆放。
(scroller?: Scroller, layoutOptions?: GridLayoutOptions): GridAttribute;
设置最后的删除按钮占两格。
layoutOptions: GridLayoutOptions = {
regularSize: [1, 1],
irregularIndexes: [this.mEnglishList.length - 1],
onGetIrregularSizeByIndex: (_: number) => {
return [1, 2]
}
}
数据源
mEnglishList = [
"Q", "W", "E", "R", "T", "Y", "U", "O", "P",
"A", "S", "D", "F", "G", "H", "J", "K", "L",
"Z", "X", "C", "V", "B", "N", "M", ""]
代码实现
Grid(undefined, this.layoutOptions) {
ForEach(this.mEnglishList, (item: string, index: number) => {
GridItem() {
if (index == this.mEnglishList.length - 1) {
Row() {
Column() {
Image(this.deleteIconSrc)
.width(this.deleteIconWidth)
}
.width("100%")
.height("100%")
.backgroundColor(Color.White)
.borderRadius(2)
.justifyContent(FlexAlign.Center)
}
.width("100%")
.height("100%")
.justifyContent(FlexAlign.End)
} else {
Text(item)
.fontSize(this.rectTextSize)
.fontColor(this.itemSelectedArray[index+this.mNumberList.length] ? this.rectSelectTextColor :
this.rectTextColor)
}
}.GridItemAttribute(this, index + this.mNumberList.length, item)
}, (item: string, index: number) => JSON.stringify(item) + "_" + index)
}
.columnsTemplate("1fr ".repeat(this.columnSize).trimEnd())
.columnsGap(this.columnsGap)
.rowsGap(this.rowsGap)
.margin({ top: Number(this.gridMarginTop) + 10, left: 15, right: 15 })
.scrollBar(BarState.Off)
封装使用
和车牌省份简称一样,车牌字母也进行封装,方便大家进行使用。
方式一:在Terminal窗口中,执行如下命令安装三方包,DevEco Studio会自动在工程的oh-package.json5中自动添加三方包依赖。
建议:在使用的模块路径下进行执行命令。
ohpm install @abner/keyboard
方式二:在工程的oh-package.json5中设置三方包依赖,配置示例如下:
"dependencies": { "@abner/keyboard": "^1.0.0"}
代码调用
LicensePlateLetterView({
onItemClick: (item: string, index: number) => {
//点击事件
console.log("=====点击内容:" + item + "===点击索引:" + index)
},
onDelete: () => {
//点击删除
console.log("=====点击删除")
}
})
相关属性
属性 | 类型 | 概述 |
onItemClick | (item: string, index: number) => void | 点击条目回调 |
onDelete | () => void | 点击删除回调 |
onComplete | (item: string) => void | 点击完成回调 |
rowsGap | Length | 行间距 |
columnsGap | Length | 列间距 |
columnSize | number | 展示几列,默认是10列 |
bgColor | ResourceColor | 背景颜色 |
marginLeft | Length | 距离左边 |
marginRight | Length | 距离右边 |
rectHeight | Length | 每个格子高度 |
titleHeight | Length | 标题栏高度 |
rootHeight | Length | 键盘整体的高度 |
gridMarginTop | Length | 网格距离顶部 |
gridMarginBottom | Length | 网格距离底部 |
completeTextColor | ResourceColor | 完成按钮的颜色 |
completeFontSize | number/string/ Resource | 完成文字大小 |
isShowComplete | boolean | 是否显示完成按钮 |
rectBgColor | ResourceColor | 格子背景 |
rectSelectBgColor | ResourceColor | 格子选中背景 |
rectBorderWidth | Length | 格子边框宽度 |
rectBorderRadius | Length | 格子圆角 |
rectBorderColor | ResourceColor | 格子边框颜色 |
rectBorderSelectColor | ResourceColor | 格子选中边框颜色 |
rectTextSize | Length | 格子的文字大小 |
rectTextColor | Length | 格子文字的默认颜色 |
rectSelectTextColor | ResourceColor | 格子文字的选中颜色 |
numProhibit | boolean | 是否禁止数字 |
numProhibitColor | ResourceColor | 禁止文字颜色 |
deleteIconWidth | Length | 删除图片宽度 |
deleteIconSrc | PixelMap/ResourceStr/ DrawableDescriptor | 删除icon资源 |
相关总结
车牌字母键盘和一般的键盘还有很大区别的,大家可以发现,键盘上是少一个字母的,因为I字母具有混淆性,所以这个字母是不在车牌键盘内的。