-
Notifications
You must be signed in to change notification settings - Fork 564
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
关于Ctrl+Space,小狼毫应保持与系统一致的行为模式 #1343
Comments
我在剛開始用 Windows 10 的時候嘗試過一種做法,包含以下幾個步驟:
這種方式可以始終將小狼毫選定爲當前輸入法,並支持用
我認爲「關閉鍵盤」這個狀態按照微軟拼音的演進來看,應該是過時了;如果不計較「懂輸入法」的特殊軟件,普通用戶用 更好的解法,有可能要在輸入法前端代碼裏管住,不讓系統切換。似乎有人在本站提到過可以這樣做。 |
就是要给小狼毫注册一个保留按键Ctrl+Space盖了系统的了,但是这样如果有人修改了这个还是会有机会有问题的。 |
不是註冊快捷鍵。我記得有人說系統要關閉鍵盤時會給輸入法一個消息。輸入法可以管住,不管,系統就按默認的來。這得翻翻過往的相關討論。 |
浅试过GUID_COMPARTMENT_KEYBOARD_OPENCLOSE消息收到的时候试去_SetKeyboardOpen(TRUE)会failed |
我没有你那么了解rime和weasel,所以你提出的这些问题,我不一定都能正确理解你的意思,不过我会尽可能说清楚我的观点。 概括的说,我认为weasel应该为用户提供以下的功能:
我之所以用了“系统行为”这个词,是因为不管哪个版本的Windows,在使用内置输入法的时候,都可以实现这样的工作流程。如果你觉得“系统行为”这个说法有点模糊,那么只说“用户习惯”或“工作流程”其实也可以。 当然,并不每个用户都想要默认为英文输入模式,并且还喜欢用Ctrl+Space切换输入状态。但是这个工作流程长期以来都存在,当前版本的Windows,以及其他第三方输入法,都可以保留这样的使用习惯。而且说起来,Windows 7及以前的时候,这个才是默认的工作流程。所以我认为weasel应该提供这样的功能。 上图中确实写着“输入法/非输入法切换”,不过我认为这个应该是历史遗留问题了。该窗口以及相关的文本翻译存在的时间非常久了,Ctrl+Space的实际用途在Windows 11中确实发生了变化。 |
不是提问,只是列一下曾经思考这个问题未发现解法的过程有考虑的事情。 |
那这个不是和系统保持一致了,是和微软拼音输入法等保持一致。 系统仍然将 Ctrl + Space 视作一个开启、关闭输入法的快捷键,微软拼音输入法可能覆写了。 Update: 我看有的配置方案连 ascii mode 的 processor 都没加,好像在 mac 上也正常用。 假如能实现的话,这样听起来可以
默认就还是关闭键盘好了,感觉没啥影响。 |
@oTnTh 有一点提示一下, "简体中文 - 美式键盘"是可以装回来的, 请你安装English - US语言包, 就会发现有ENG输入法了 此外这个界面并非翻译问题, 你可以看一下英文的说明和中文是相同的 实际上如果安装了rime, 微软拼音, ENG三种输入法的话, windows键+space会在三种输入法之间切换, 但是alt+shift会在上一次使用的中文输入法和ENG之间切换 如果微软拼音里把这个勾去掉的话 总而言之我觉得很难说清楚windows的intention是啥, 感觉微软自己都没想清楚, spaghetti code! |
保留按键的设置是在tsf初始化的时候引入的,猜想可能是微软拼音其实那三个按键都初始化了保留按键,勾选只是改变了这些保留按键是否执行设定的中英文切换动作。如果我猜想的情况是真的,那就会出现ctrl+space既没有开关键盘也没有切换中英文的状态,这样就解释得通了。 至于微软多个快捷键的输入定义逻辑潜在可能有意图不明确的问题,猜想是因为输入法是分开不同团队做的,保留按键没有作为需求输入,于是各干各的就容易出现组合之后意图不明确的情况了。 |
@terrytw "ime/Noime Toggle"和“输入法/非输入法切换”,这两句话,以及起所在的窗口,已经存在非常久了,至少Windows 8之前就在。在那个时候,Ctrl+Space确实是用来开关输入法的。 但是Windows 11的微软拼音中,Ctrl+Space是用来切换中英文输入模式的。行为模式确实出现了变化,但是上面那个窗口及其内容和翻译都没有发生变化,所以我才说这个是“历史遗留问题”。 在“语言和区域”中添加“英语(美国)”之后,实际上是添加了另外一种语言: 1、win+tab会弹出窗口,在rime、微软拼音和eng之间切换; 看起来“系统行为”这个词还是引发了一点争议,不过我的本意重点其实不在这里。 1、默认为英文输入模式。 这个使用习惯长期以来都存在,并且现在在其他绝大部分主流输入法内依然可以实现,但是小狼毫不行。 诚然,解决办法是有的,shift也好,安装eng然后win+tab切也好,但这些法子其实都是让用户去改变使用习惯。如果没有非常必要且充足的理由,我觉得还是不要这样做比较好。 |
关闭输入法也好,ascii_mode也罢,都是好用与更好用的区别 |
我也用 Ctrl + 空格,中英切换,很好解决,AHK 写个快捷键就搞定了。 |
调整注册表, 把 ctrl+space 开关输入法的功能给关了, 谁也不准用完事 |
是不是只要關閉二樓所示系統設置裏那個快捷鍵就行了? rime 支持自定義快捷鍵。只要系統不禁用輸入法,rime 就能處理這個快捷鍵,用來切換內部的狀態。 根據我的總結,rime 的配置文件只能控制 rime 在接收到 Control+space 之後切換自身狀態,但管不到系統的快捷鍵。系統快捷鍵會優先執行,先把輸入法禁用了,因此 rime 就收不到了。 所以,系統的語言設置那裏禁用輸入法的快捷鍵也要一併改,給小狼毫設置 Control+space 的快捷鍵才能生效。 |
这里有一个基于旧版小狼毫做的修改版,可以使用ctrl+space切换ascii模式: 4e20ebf 虽然我不是很懂,不过我猜应该是系统捕获ctrl+space被按下后,就向”当前输入法“发送了一个特定的消息,由输入法来决定要怎么处理。操作系统应该不会直接进行”关闭输入法“的操作,至少Win10以后应该是这样的。 至于AHK脚本之类的,即便默认该脚本绝对不会崩溃,也需要额外的手段解决如何往特权窗口发送消息的问题。作为一个临时方案或许可以,但其实并没有根本解决问题。 |
@fxliang 好的,非常感谢。等nightly build出来以后,我去测试一下。 |
先试下ci产出吧,合并了再报问题又得折回去,麻烦 |
我在虚拟机 Win11 测试了下:
希望跟随 rime 配置,禁用 ascii 切换功能。 |
看来我原来担心的是真实存在的🐶 |
CI版本我装上了,初看来ctrl+space确实可以切换ascii模式了。至于其他,用一用再来汇报情况。 |
在中文模式,已有输入但未上屏字符,切换英文是不是会清掉? |
c380242#diff-ca01fbb0ebc4d8472b6965db870e611e61f5258dfbec52aaabf4fb2ab31124a0R256-R262 我反倒惊讶,原来 Weasel 切 ascii 模式,完全不需要配置里面有 ascii_composer。 不知道 Weasel 能不能知道用户当前配置有没有这项呢? 另外,像那个配置一样,即使没有 ascii_composer,macOS Squirrel 也是一样能变成英文输入,不知道是不是类似于原本的那种关闭了键盘,还是说 Squirrel 也是类似于 fcitx5-rime 那样是某个框架下面的一个东西。 |
看一下 |
我知道啊,我是想问你 ctrl + space 切换是走的 ascii_composser 还是 key_binder。ctrl + space 中切英,会不会 commit_code |
提交或者清都不是问题,没有ascii_mode的方案才麻烦 |
@mirtlebot 印象中librime没有接口可以直接判断方案有没有某个option,而且那个是在服务端,到应用这里还有IPC。原来小狼毫的逻辑应该是默认都有ascii_composer的,所以状态里面固化了有ascii_mode, half/full这些 |
这个应该是因为,没有ascii_composer,但是却留下了ascii_segmentor,于是就这样了@mirtlebot |
我去看了一下前面提到的,没有ascii_composer的方案: https://github.com/LufsX/rime/blob/master/lufs_pinyin.schema.yaml 看原作者的意思,不同的平台也是需要不同的配置的。
|
新加两行,切换ascii后清空composition |
感谢你的 PR 和回复。 似乎这个问题并非此 PR 需要解决的问题,牵扯的东西应当不只这个议题。 比如,我刚刚翻看了之前使用命令参数修改 ascii mode 的 PR,https://github.com/rime/weasel/pull/1113/files 。应当同样是没有对无 ascii mode 的配置做调整。 此外,这个问题影响很小,很少有配置这么写。即使有,暂时要求配置添加对应 processor 即可。 看一看有没有其他副作用,大概就可以合并入主分支了。 |
Option 似乎并不重要,如那个方案,有 Option,但完全无作用,只要看 engine(processor 和 segmentors)即可。而 librime-lua 提供了获取方案 engine 的 lua API,因此 librime 应当有对应的 API。 至于判断起来方不方便就在我能力之外了。如上评论,感觉这种情况不需要在这个 PR 中解决。 |
关于这点,我的方案还使用 lua hack 了 ascii mode,而用 ctrl+space 是希望回到正常的 qwertry 键盘。 我赞同将与系统不一致的行为视作 bug 修复,但更改默认行为的更新是否该更慎重一点?今天更新后对 ctrl+space 切换 ascii 的行为摸不着头脑,最后找到本 Issue。 |
更新后的版本用Ctrl+Space不能切换时上屏原始的编码,请问怎么配置。 |
好像并不能配置 |
@fxliang 大佬关于这个问题,后面会继续更改,还是保持现状 |
想知道你是怎么用lua hack的,最新版本能否用lua方式实现Ctrl+space上屏编码 |
我搜了一下,Ctrl+Space的问题在本项目曾经被提出过好几次,不过提交者都没有把该问题说得很明白,所以我想再尝试说明一下这个问题。
过去的Windows中,输入法设置是上图这个样子。
“默认输入语言”是“简体中文 - 美式键盘”,Ctrl+Space可以实现“美式键盘”跟“中文(简体) - 谷歌拼音输入法”之间的切换。
而在Windows 11中,输入法的行为模式已经发生了变化。
“简体中文 - 美式键盘”不再存在,按照上图的设置,开机后“微软拼音”就会默认开启。
如果想要开机默认是可以输入英文的模式,需要在“微软拼音”输入法中进行设置。
最重要的,也是小狼毫与系统行为模式不一致的地方。
Ctrl+Space在Windows 11中的功能,是用于“中/英文模式切换”,类似于小狼毫中的切换ascii_mode,而非过去那样“开启/关闭输入法”。
目前小狼毫的行为模式,会导致一直以来都存在,并且在其他主流输入法中依然可以使用的操作习惯出现问题:
简单来说,就是默认输入英文,并且Ctrl+Space用作中文/英文的切换快捷键。
然而该操作流程,目前在小狼毫中是无法实现的。
这个问题之所以时不时有人提出,但又没有影响所有人,是不同的使用习惯导致的。
虽然这个问题说到底,还是Windows修改了输入法的行为模式导致的,不过我还是认为维护用户的使用习惯是很重要的。
写得有点长,图也很多,没找到法子能排版得更友好一点,非常感谢看到这里的人,谢谢。
The text was updated successfully, but these errors were encountered: