Introduction and description of harmony-utils
harmony-utils A HarmonyOS tool library with rich features and extremely easy to use, with the help of many practical tools, is committed to helping developers quickly build Hongmeng applications. Its encapsulated tools cover APP, device, screen, authorization, notification, inter-thread communication, pop-up frames, toast, biometric authentication, user preferences, taking photos, albums, scanning codes, files, logs, exception capture, characters, strings, numbers, collections, dates, random, base64, encryption, decryption, JSON and other functions, which can meet various development needs.
picker_utils It is a sub-store split by harmony-utils, including PickerUtil, PhotoHelper, and ScanUtil.
Download and install
ohpm i @pura/harmony-utils
ohpm i @pura/picker_utils
//Global initialization method, initialized in the onCreate method of UIAbility AppUtil.init()
onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
AppUtil.init(this.context);
}
API methods and usage
show Pull up the keyboard
KeyboardUtil.show("id_input_1000");
hide hidden keyboard
KeyboardUtil.hide();
onKeyboardListener Subscribe to input method soft keyboard to show and hide events
KeyboardUtil.onKeyboardListener((show, height) => {
LogUtil.error("onKeyboardListener-B: " + height);
if (show) {
ToastUtil.showToast(`键盘显示,高度为:${height}`);
} else {
ToastUtil.showToast(`键盘已关闭!`);
}
});
removeKeyboardListener Unsubscribe from input method soft keyboard to display or hide events
KeyboardUtil.removeKeyboardListener(); //移除所有
KeyboardUtil.removeKeyboardListener(callback); //移除指定
Full Code Example
import { router } from '@kit.ArkUI';
import { MockSetup } from '@ohos/hamock';
import { KeyboardCallBack, KeyboardUtil, LogUtil, ToastUtil } from '@pura/harmony-utils';
import { TitleBarView } from '../../component/TitleBarView';
import { DescribeBean } from '../../model/DescribeBean';
/**
* 键盘工具类
*/
@Entry
@Component
struct Index {
private scroller: Scroller = new Scroller();
private controller: TextInputController = new TextInputController()
@State describe: DescribeBean = router.getParams() as DescribeBean;
private callback: KeyboardCallBack = (show, height) => {
LogUtil.error("onKeyboardListener-A: " + height);
if (show) {
ToastUtil.showToast(`键盘显示!高度为:${height}`);
} else {
ToastUtil.showToast(`键盘已关闭!`);
}
};
@MockSetup
mock() {
this.describe = new DescribeBean("KeyboardUtil", "键盘工具类");
}
build() {
Column() {
TitleBarView({ describe: this.describe })
Divider()
Scroll(this.scroller) {
Column() {
Button("show(),主动拉起键盘")
.btnStyle()
.onClick(() => {
KeyboardUtil.show("id_input_1000");
})
Button("hide(),关闭键盘")
.btnStyle()
.onClick(() => {
KeyboardUtil.hide();
})
Button("onKeyboardListener()")
.btnStyle()
.onClick(() => {
KeyboardUtil.onKeyboardListener((show, height) => {
LogUtil.error("onKeyboardListener-B: " + height);
if (show) {
ToastUtil.showToast(`键盘显示,高度为:${height}`);
} else {
ToastUtil.showToast(`键盘已关闭!`);
}
});
})
Button("removeKeyboardListener()")
.btnStyle()
.onClick(() => {
KeyboardUtil.removeKeyboardListener(); //移除所有
})
Button("onKeyboardListener()-指定")
.btnStyle()
.onClick(() => {
KeyboardUtil.onKeyboardListener(this.callback);
})
Button("removeKeyboardListener()-指定")
.btnStyle()
.onClick(() => {
KeyboardUtil.removeKeyboardListener(this.callback); //移除指定
})
TextInput({ placeholder: '请输入', controller: this.controller })
.margin({ top: 30 })
.width('90%')
.id("id_input_1000")
Blank().layoutWeight(1)
}
.margin({ top: 5, bottom: 5 })
}
.layoutWeight(1)
}
.width('100%')
.height('100%')
.justifyContent(FlexAlign.Start)
.backgroundColor($r('app.color.main_background'))
}
}
@Styles
function btnStyle() {
.width('90%')
.margin({ top: 10, bottom: 5 })
}
Top comments (0)