Skip to content

基于vue的一款js键盘,支持拼音输入和手写输入

License

Notifications You must be signed in to change notification settings

bonyz/vue-dusion-keyboard

 
 

Repository files navigation

vue-dusion-keyboard

基于vue.js的一款js键盘,支持拼音输入手写输入electron下可离线运行,临时demo地址


安装

npm安装

npm install vue-dusion-keyboard -S

在 main.js 中写入以下内容全局注册:

全部注册
import VueDusionKeyboard from 'vue-dusion-keyboard'
Vue.use(VueDusionKeyboard)

或者按组件注册
import {VueDusionKeyboard,Paint} from 'vue-dusion-keyboard'
Vue.component('VueDusionKeyboard', VueDusionKeyboard)
Vue.component('Paint', Paint) //可省略

标签引入

<!--先引入vue.js-->
<script src="https://cdn.bootcss.com/vue/2.6.10/vue.min.js"></script>
<script src="./VueDusionKeyboard.umd.min.js"></script>
<script>
new Vue({}).$mount('#app')
</script>

使用

在非all模式下,input标签添加属性data-mode,然后在合适位置放置组件<vue-dusion-keyboard></vue-dusion-keyboard>即可。

<input type="text" data-mode="en_cap" />
<vue-dusion-keyboard float></vue-dusion-keyboard>

组件添加all属性即可为所有input标签注册弹出键盘

<vue-dusion-keyboard all float :blurHide="true" observer></vue-dusion-keyboard>

对于js动态生成的输入框,vue-dusion-keyboard提供以下两种方法注册

  • 加入监听属性observer
<vue-dusion-keyboard all float observer></vue-dusion-keyboard>
  • 当有新的input标签生成时,重新调用sign_up_keyboard方法注册。
window.sign_up_keyboard();

Paint组件

  • paint组件为vue-dusion-keyboard内置写字板组件
<paint hand-write-api="http://jsrtj.fotoit.cn/iis/HandWriteApi/words" @result="result"></paint>

模式

离线模式

组件默认为离线模式,离线模式需要运行在electron环境下,所需的控件有:

nodejs模块:
  • ffi
  • ref

ffi安装失败的小伙伴可以安装:

  • ffi-napi
  • ref-napi
C++库:
  • XDLL.dll : 放置在electron根目录的plug\\handWrite\\XDLL.dll下。
手写字库:
  • hz.mrd : 中文字库,放置在XDLL.dll同目录下。
  • English.mrd : 英文字库,放置在XDLL.dll同目录下。

以上文件可加qq751069244索取

互联网模式

组件上添加hand-write-api属性即可切换互联网模式,可以直接运行在浏览器中

手写输入互联网接口地址见临时demo地址
注意:临时地址仅供学习之用,随时可能关闭。


Animate.css

此项目引用了animate.css,用于键盘显示隐藏的过渡动画,内置fadeInUp和fadeOutDown,如需其他效果,请引入animate.css文件,然后配置属性enter-active-classleave-active-class


input标签属性

属性 说明 类型 可选值 默认值
data-mode 弹出输入法的类型:
en_let 英文小写
en_cap 英文大写
cn 中文
hand 手写
String en_let
en_cap
cn
hand
en_let

组件属性

vue-dusion-keyboard:

属性 说明 类型 可选值 默认值
all 是否为所有input标签注册弹出输入法 Boolean true/false false
observer 开启后会使用MutationObserver对dom更改进行监听,如果有新的input标签生成即为其注册键盘弹起事件 Boolean true/false true
float 是否使输入法组件浮动在当前input标签下方 Boolean true/false true
blurHide input标签失去焦点时是否隐藏输入组件 Boolean true/false true
size 组件大小,mini最小支持宽度1080px,默认最小宽度则是1330px String primary/mini primary
enter-active-class 输入组件弹出来的动画效果,基于Animate.css String Animate.css 官网 fadeInUp
leave-active-class 输入组件隐藏时的动画效果 String 同上 fadeOutDown
hand-write-api 手写输入接口地址,不传则为离线electron模式 String demo
dll-path 手写库dll路径,默认为plug\\handWrite\\ String plug\\handWrite\\
pun_keys 替换标点符号(16个) Array
num_pun_keys 替换数字键盘左侧标点符号(4个) Array

paint:

属性 说明 类型 可选值 默认值
show_result 是否在右侧显示结果 Boolean true/false true
p_width 画板宽度 number - 600
p_height 画板高度 number - 400
lib 手写识别库 string CN/EN CN
hand-write-api 手写输入接口地址,不传则为离线electron模式 String demo
dll-path 手写库dll路径,默认为plug\\handWrite\\ String plug\\handWrite\\

组件方法

vue-dusion-keyboard:

方法名 说明 参数
sign_up_keyboard 重新注册input显示键盘,当页面有新的input标签出现时调用此方法 event
paint:

组件事件

vue-dusion-keyboard:paint:

事件名 说明 参数
result 手写识别结果 string[]

更新

v2.0.0

  • vue cli改用3.x以上版本
  • 改用typescript编写(非class写法)
  • 新增属性observer,监听dom变化,为新增input标签注册键盘弹起事件
  • 标点符号改为16个,可通过属性pun_keys替换
  • 数字键盘左侧增加四个标点符号按钮,可通过属性num_pun_keys替换
  • float属性默认为true

v2.1.0

  • ffi模块如果找不到则会加载ffi-napi,ref同理
  • 新增dll-path属性,可自定义手写库的路径

v2.2.0

  • 改回1.x时Vue.use()的引入方式
  • 可单独导出Paint组件

About

基于vue的一款js键盘,支持拼音输入和手写输入

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Vue 73.4%
  • TypeScript 16.9%
  • CSS 7.5%
  • HTML 1.9%
  • JavaScript 0.3%