笔记-Rime中州韵输入法配置记录

2024-03-23 22:40

本文主要是介绍笔记-Rime中州韵输入法配置记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2023年12月29日更新:增加配色方案,增加默认英文输入配置 

2023年12约30日更新:修复已知错误(修改字号字段拼写错误)

2024年1月2日更新:添加网址模式(****.schema.yaml)

2024年1月8日更新:添加模糊音配置

近日,初步使用小狼豪输入法,感觉相当舒适,现将配置过程在本站做一个记录,以备后续翻阅查找。

注意:缩进用的时空格,不可用tab键,:后如果有值,需空一格。

一、安装

官方网站:RIME | 中州韻輸入法引擎

安装过程略。

二、配置

1、定义自定义输入方案

在用户文件夹下创建d.schema.yaml文件,编码utf-8,文件内容如下:

(大部分内容为luna_pinyin.schema.yaml照搬)

# Rime default settings
# Rime schema: TF
# Rime dictionary: my_dictionary
schema:schema_id: name # 内部使用name: #方案选择时显示version: "0.1"author:- Downloaddescription: Rime 自定义的拼音輸入方案。switches:- name: ascii_mode # 中英文切换开关reset: 1states: [ 中文,英文 ]- name: full_shape # 全角半角切换开关reset: 0states: [ 半角,全角 ]- name: ascii_punct # 中西文切换开关reset: 0states: [ 中文标点,英文标点 ]- name: simplificationreset: 1states: [ 漢字,汉字 ]  
engine:processors:# 1.2版本加入的- fluid_editor # 将字符按键记入输入上下文,将输入法连缀成一串- ascii_composer # 处理英文模式及中英文切换- recognizer # 与 matcher 搭配,处理符合特定规则的输入码,如网址、反查等- key_binder # 在特定条件下将按键绑定到其他按键,如重定义逗号、句号为候选翻页键- speller # 1.3版本加入 把字母追加到编码串- punctuator # 处理符号按键- selector # 1.5版本加入 选字和换页功能- navigator # 移动插入点- express_editor # 1.3版本加入 空格确认当前输入,其他字符直接上屏segmentors:- ascii_segmentor- matcher- abc_segmentor # 1.4版本加入 标记输入码的类型- punct_segmentor # 割界,与前后方的其他编码区分开- fallback_segmentor # 1.2版本加入的translators:- echo_translator # 没有其他结果时,创建一个与编码串一样的候选项- punct_translator # 转换标点符号- script_translator # 脚本表转换# - reverse_lookup_translator # 反查翻译器?不知道有锤子用filters:- simplifier # 简繁转换- uniquifier # 过滤重复的候选字,有可能来自简繁转换
key_binder:bindings:- {accept: "Control+p", send: Up, when: composing}- {accept: "Control+n", send: Down, when: composing}- {accept: "Control+b", send: Left, when: composing}- {accept: "Control+f", send: Right, when: composing}- {accept: "Control+a", send: Home, when: composing}- {accept: "Control+e", send: End, when: composing}- {accept: "Control+d", send: Delete, when: composing}- {accept: "Control+k", send: "Shift+Delete", when: composing}- {accept: "Control+h", send: BackSpace, when: composing}- {accept: "Control+g", send: Escape, when: composing}- {accept: "Control+bracketleft", send: Escape, when: composing}- {accept: "Control+y", send: Page_Up, when: composing}- {accept: "Alt+v", send: Page_Up, when: composing}- {accept: "Control+v", send: Page_Down, when: composing}- {accept: ISO_Left_Tab, send: "Shift+Left", when: composing}- {accept: "Shift+Tab", send: "Shift+Left", when: composing}- {accept: Tab, send: "Shift+Right", when: composing}- {accept: minus, send: Page_Up, when: has_menu}- {accept: equal, send: Page_Down, when: has_menu}- {accept: comma, send: Page_Up, when: paging}- {accept: period, send: Page_Down, when: has_menu}- {accept: "Control+Shift+1", select: .next, when: always}- {accept: "Control+Shift+2", toggle: ascii_mode, when: always}- {accept: "Control+Shift+3", toggle: full_shape, when: always}- {accept: "Control+Shift+4", toggle: simplification, when: always}- {accept: "Control+Shift+5", toggle: extended_charset, when: always}- {accept: "Control+Shift+exclam", select: .next, when: always}- {accept: "Control+Shift+at", toggle: ascii_mode, when: always}- {accept: "Control+Shift+numbersign", toggle: full_shape, when: always}- {accept: "Control+Shift+dollar", toggle: simplification, when: always}- {accept: "Control+Shift+percent", toggle: extended_charset, when: always}import_preset: default
translator:dictionary: qq # 设定table_translator使用的词典名enable_encoder: true # 开启自动造词enable_completion: true # 提前显示尚未输入完整码的字enable_sentence: true # 是否开启自动造句enable_user_dict: true # 开启用户词典〔用户词典记录动态字词频、用户词〕preedit_format: # 上屏码自定义- xform/([nl])v/$1ü/ # 拼音状态下输入nv实际显示nü- xform/([nl])ue/$1üe/ # n或者l后面紧跟着输入ue显示üe- xform/([jqxy])v/$1u/ # j q x y 后面紧跟着输入v 实际显示upunctuator: # 设定符号表,这里直接导入预设的import_preset: default # 引入default.yaml中自定义的符号表speller:alphabet: qwertyuiopasdfghjklzxcvbnm # 输入范围delimiter: " '"algebra: # 拼音运算规则 我也不懂 照抄的作者的代码- erase/^xx$/- abbrev/^([a-z]).+$/$1/- abbrev/^([zcs]h).+$/$1/- derive/^([nl])ve$/$1ue/- derive/^([jqxy])u/$1v/- derive/un$/uen/- derive/ui$/uei/- derive/iu$/iou/- derive/([aeiou])ng$/$1gn/- derive/([dtngkhrzcs])o(u|ng)$/$1o/- derive/ong$/on/- derive/ao$/oa/- derive/([iu])a(o|ng?)$/a$1$2/custom_phrase: # 用户词典位置dictionary: ""user_dict: my_dict # 用户词典名称 可以在build文件夹下看到一个my_dict.userdb.txt文件,里面就是按照用户的输入习惯形成的词库db_class: stabledbinitial_quality: 1simplifier:option_name: simplification # 繁体转换为简体opencc_config: t2s.json # 转换工具tags: [ abc ] # 转换文字段tips: nonekey_binder:import_preset: default # 引入按键绑定recognizer:import_preset: defaultpatterns:email: "^[A-Za-z][-_.0-9A-Za-z]*@.*$" # 匹配email格式uppercase: "[A-Z][-_+.'0-9A-Za-z]*$" # 大写字母# url: "^(www[.]|https?:|ftp[.:]|mailto:|file:).*$|^[a-z]+[.].+$"url: "^(www[.]|https?:|ftp[.:]|mailto:|file:).*$|^[a-z]+[.]$"

保存,重新部署后,在方案中选择此方案,点击“中”。

2、字典定义:

总字典
--- 
name: myDict                 #必须与文件名相同,此处不加文件后缀 
version: "2014.10.28" 
sort: by_weight 
use_preset_vocabulary: true ​ 
import_tables:              #导入词库- A                       #将所有词库以这种方式写入- B                       #注意,不需要写扩展名- C - D...
# Rime dictionary
# encoding: utf-8---
name: qq # 字典名称
version: "2021.02.05" 版本号
sort: by_weight
use_preset_vocabulary: true...
啊	a	17967  #字典内容
阿	a	46
啊哎哎	a ai ai	1
啊按	a an	1
啊吧	a ba	2
啊把	a ba	1

3、外观设置:

# weasel.custom.yaml
patch:style/horizontal: true      # 候選橫排style/inline_preedit: true  # 內嵌編碼(僅支持TSF)style/display_tray_icon: false  # 顯示托盤圖標style/corner_radius: 20 # 圆角style/font_face: "楷体"style/font_point: 18style/color_scheme: tf # 选择配色方案"preset_color_schemes/tf": # 自定义配色方案name: tfauthor: dtext_color: 1710618back_color: 16382457border_color: 15658734label_color: 11184810hilited_text_color: 1710618hilited_back_color: 15790320candidate_text_color: 1710618comment_text_color: 1710618hilited_candidate_text_color: 1710618hilited_comment_text_color: 1710618hilited_candidate_back_color: 15790320hilited_label_color: 11184810

效果图:

自用外观2:

 # wealsel.custom.yaml
style/horizontal: true      # 候選橫排style/inline_preedit: true  # 內嵌編碼(僅支持TSF)style/display_tray_icon: false  # 顯示托盤圖標style/corner_radius: 8 # 圆角style/font_face: "楷体"sytle/font_point: 20"style/layout/border_width": 0"style/layout/border": 0"style/layout/margin_x": 8 #候选字左右边距"style/layout/margin_y": 6 #候选字上下边距"style/layout/hilite_padding": 5 #候选字背景色色块高度 若想候选字背景色块无边界填充候选框,仅需其高度和候选字上下边距一致即可"style/layout/hilite_spacing": 3 # 序号和候选字之间的间隔"style/layout/spacing": 10 #不知道干嘛的,在weasel下好像没有效果"style/layout/candidate_spacing": 12 # 候选字间隔#"style/layout/round_corner": 0 #候选字背景色块圆角幅度style/color_scheme: ios # 选择配色方案
"preset_color_schemes/ios": #ios手机输入法配色name: iosauthor: Downback_color: 0xDCD3CFborder_color: 0xDCD3CFtext_color: 0xFFFFFFhilited_text_color: 0xFFFFFFhilited_back_color: 0xDCD3CFhilited_candidate_text_color: 0x000000hilited_candidate_back_color: 0xFFFFFFcandidate_text_color: 0x000000comment_text_color: 0xFFFFFF

效果4、全局默认英文输入,特定app下使用中文输入

#wealsel.custom.yaml
patch: # 程序名称全部用小写app_options/wechat.exe:ascii_mode: falseapp_options/qq.exe:ascii_mode: falseapp_options/dingtalk.exe:ascii_mode: falseapp_options/dingtalkgov.exe:ascii_mode: false#luna_pinyin.schema.yaml
switches:- name: ascii_mode # 中英文切换开关,reset值为1默认英文输入reset: 1states: [ 中文,英文 ]- name: full_shape # 全角半角切换开关reset: 0states: [ 半角,全角 ]- name: ascii_punct # 中西文切换开关reset: 0states: [ 中文标点,英文标点 ]- name: simplificationreset: 1states: [ 漢字,汉字 ]  

5、使用方括号翻页,shift键切换中英文

#default.custom.yaml
patch:key_binder/bindings:- { when: paging, accept: bracketleft, send: Page_Up }- { when: has_menu, accept: bracketright, send: Page_Down }

6、模糊音配置

根据实际情况,删除前面的#,使配置生效

# XXX.custom.yaml 
# UTF-8
patch:'speller/algebra':- erase/^xx$/  # 模糊音定義# 需要哪組就刪去行首的 # 號,單雙向任選- derive/^([zcs])h/$1/             # zh, ch, sh => z, c, s- derive/^([zcs])([^h])/$1h$2/     # z, c, s => zh, ch, sh- derive/^n/l/                     # n => l- derive/^l/n/                     # l => n# 這兩組一般是單向的- derive/^r/l/                     # r => l#- derive/^ren/yin/                 # ren => yin, reng => ying#- derive/^r/y/                     # r => y# 下面 hu <=> f 這組寫法複雜一些,分情況討論- derive/^hu$/fu/                  # hu => fu- derive/^hong$/feng/              # hong => feng- derive/^hu([in])$/fe$1/          # hui => fei, hun => fen- derive/^hu([ao])/f$1/            # hua => fa, ...- derive/^fu$/hu/                  # fu => hu- derive/^feng$/hong/              # feng => hong- derive/^fe([in])$/hu$1/          # fei => hui, fen => hun- derive/^f([ao])/hu$1/            # fa => hua, ...# 韻母部份- derive/^([bpmf])eng$/$1ong/      # meng = mong, ...- derive/([ei])n$/$1ng/            # en => eng, in => ing- derive/([ei])ng$/$1n/            # eng => en, ing => in# 樣例足夠了,其他請自己總結……# 反模糊音?# 誰說方言沒有普通話精確、有模糊音,就能有反模糊音。# 示例爲分尖團的中原官話:#- derive/^ji$/zii/   # 在設計者安排下鳩佔鵲巢,尖音i只好雙寫了#- derive/^qi$/cii/#- derive/^xi$/sii/#- derive/^ji/zi/#- derive/^qi/ci/#- derive/^xi/si/#- derive/^ju/zv/#- derive/^qu/cv/#- derive/^xu/sv/# 韻母部份,只能從大面上覆蓋#- derive/^([bpm])o$/$1eh/          # bo => beh, ...#- derive/(^|[dtnlgkhzcs]h?)e$/$1eh/  # ge => geh, se => sheh, ...#- derive/^([gkh])uo$/$1ue/         # guo => gue, ...#- derive/^([gkh])e$/$1uo/          # he => huo, ...#- derive/([uv])e$/$1o/             # jue => juo, lve => lvo, ...#- derive/^fei$/fi/                 # fei => fi#- derive/^wei$/vi/                 # wei => vi#- derive/^([nl])ei$/$1ui/          # nei => nui, lei => lui#- derive/^([nlzcs])un$/$1vn/       # lun => lvn, zun => zvn, ... #- derive/^([nlzcs])ong$/$1iong/    # long => liong, song => siong, ...# 這個辦法雖從拼寫上做出了區分,然而受詞典制約,候選字仍是混的。# 只有真正的方音輸入方案纔能做到!但「反模糊音」這個玩法快速而有效!# 模糊音定義先於簡拼定義,方可令簡拼支持以上模糊音- abbrev/^([a-z]).+$/$1/           # 簡拼(首字母)- abbrev/^([zcs]h).+$/$1/          # 簡拼(zh, ch, sh)# 以下是一組容錯拼寫,《漢語拼音》方案以前者爲正- derive/^([nl])ve$/$1ue/          # nve = nue, lve = lue- derive/^([jqxy])u/$1v/           # ju = jv,- derive/un$/uen/                  # gun = guen,- derive/ui$/uei/                  # gui = guei,- derive/iu$/iou/                  # jiu = jiou,# 自動糾正一些常見的按鍵錯誤- derive/([aeiou])ng$/$1gn/        # dagn => dang - derive/([dtngkhrzcs])o(u|ng)$/$1o/  # zho => zhong|zhou- derive/ong$/on/                  # zhonguo => zhong guo- derive/ao$/oa/                   # hoa => hao- derive/([iu])a(o|ng?)$/a$1$2/    # tain => tian# 分尖團後 v => ü 的改寫條件也要相應地擴充:'translator/preedit_format':- "xform/([nljqxyzcs])v/$1ü/"

这篇关于笔记-Rime中州韵输入法配置记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

springboot security之前后端分离配置方式

《springbootsecurity之前后端分离配置方式》:本文主要介绍springbootsecurity之前后端分离配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的... 目录前言自定义配置认证失败自定义处理登录相关接口匿名访问前置文章总结前言spring boot secu

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML

springboot简单集成Security配置的教程

《springboot简单集成Security配置的教程》:本文主要介绍springboot简单集成Security配置的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录集成Security安全框架引入依赖编写配置类WebSecurityConfig(自定义资源权限规则

SpringBoot中封装Cors自动配置方式

《SpringBoot中封装Cors自动配置方式》:本文主要介绍SpringBoot中封装Cors自动配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot封装Cors自动配置背景实现步骤1. 创建 GlobalCorsProperties

Spring Boot结成MyBatis-Plus最全配置指南

《SpringBoot结成MyBatis-Plus最全配置指南》本文主要介绍了SpringBoot结成MyBatis-Plus最全配置指南,包括依赖引入、配置数据源、Mapper扫描、基本CRUD操... 目录前言详细操作一.创建项目并引入相关依赖二.配置数据源信息三.编写相关代码查zsRArly询数据库数

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE