From 8bd0c226708cec39771d7a9c08c43b81ac7d8130 Mon Sep 17 00:00:00 2001 From: misyaguziya Date: Tue, 30 May 2023 00:21:30 +0900 Subject: [PATCH 1/9] add information --- img/config-icon-white.png | Bin 0 -> 5490 bytes img/info-icon-white.png | Bin 0 -> 4945 bytes 2 files changed, 0 insertions(+), 0 deletions(-) create mode 100644 img/config-icon-white.png create mode 100644 img/info-icon-white.png diff --git a/img/config-icon-white.png b/img/config-icon-white.png new file mode 100644 index 0000000000000000000000000000000000000000..1222f16707e579ff4321ebf94bc36f9756ab7e62 GIT binary patch literal 5490 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 literal 0 HcmV?d00001 diff --git a/img/info-icon-white.png b/img/info-icon-white.png new file mode 100644 index 0000000000000000000000000000000000000000..210613e03a30370a1821eb81a53c181084186de5 GIT binary patch literal 4945 zcmeHKX;2f{7ES6`%#eBb7kXf@w1?@lw>_RQM1%R;*IXl?L7`_mCk{%ymA0^WFhe12R# zwXyVv5t++Y`S7gW{2(>D za|{!I2)6mYot+wEw6T6pg!w+SYv~^ivGtkF6bdyH4+sbs2LybK2Sib{I7b+Aa`MR9 zd9$);-}U!h>8aSoXcCD=h7Qe&*-|<5`vmwPNy6uFtVuJ0iLad~P#rk>9(8Kc_4W92<)G4wZ zn?jh%X8zIE+jpMK&5TVhey{8BO5Q;A&*7aTPtuIgrr#>b`uC?s&(3vf(Y1&(7$Kc! z6K>q&){9p3+cX?Oeo1a|*cbIQ=1@j-UHGcll_yu1&OEw4A^LVrZFJe?s3)5`mmRO! zpL<_$(ec#2Osian(c6|IY;ObX$_b&8I@z{dt<%kR4IeeLIU3x4fa_FOfDvd4*fa z91|sCYI00p2!*`YUX!4WH;1E;GqHF~1yprlSJr1+28$)(y%r`4VsVwmYz4^vOq0Zw zpUC>mHW!gvOvdKOQ4Zh7n=kJJC06T5R4vC$Pyn2P0~|IV<^Tj49YYW{ovq-> z=rWAUqH_^0hs~D3as?Od12IF3gRDg3`+8-9QkbBW2#d=BP_Tl}r?WW<9-YtgQP8<^ zmYgd`5tOTxnV}SNK@g!;q2M@i6&i~%HR@Qiz(lxUO1M}^Lm2RNwnZ&H+$H2N~N-83NOoJ;5?f9phuPe#}4d z;b&Ip(_(;K_Znzjpc68CTVW4hrl#{ZK0W8~H|_wSzi#qH{C=hDD_vj2z!xch&91L> zeGvm+r2I9z{%>^Ie!5IyYVZ$853Wi?(6(T3&9at-1_zoiT$Hx~hnIknjV2^oN1@ma zF}+kuVUY`1>`#g%qW%y1xec1=l&KrCkV3KO6bDX`&Nn{$sUcK4)9K8y$jVcrDzj|q zW6zAbJbPF^J!`%5_6d=%n3*m?qo3t!3s&!5s)=mcRoU>btt8c;~pPkW&5f57U~~cN}-A zIMlY4Qe@$gW`FLEw`SPGTZ5PDDbdgj&E53m&BAuNl~i0k`cZy~WqI*|v1QZVc|0oc zPK=7EC{c^6%HR6tszY75r|)i9nIimsPe@>~MP%ALq~;I9RL8E`h?<$MAI@!mW8XL{ zeUGp8FM3aE(x zgRnWz52Ww+bUR!9Dz$2``=Yq%?{0-naBkS($@KDVc>N~3X2kGOsYkAM&Ye`SvG}C+ zN;UI8r+>V*?+WL1&H75k4Iigk+w1p^-=m~%n9`7a@*2@zwt~}jaNN^*jU(OeI?VC2 zH{@?W;FWE;IDhj4o2yah^Nm^C@8_TQpgV8ez4@Q6q<`!hmQ_qc@^y#n=|Ndtj_~@7 zT=$`!IqVT>uMdkx*=|^Ng6&u4ywRp`eP`Ij2L>X`zc6O^!V4#t8wRCTJ=|gCwl`t1 z%^ky{tX6B+Z_Z9$lUwZ-#PFT~# z6`bZljgEBzlLywb3;z_{9Ba( literal 0 HcmV?d00001 From 41a3b876b6c03f97538701e954264bd009b8ca2b Mon Sep 17 00:00:00 2001 From: misyaguziya Date: Tue, 30 May 2023 00:34:37 +0900 Subject: [PATCH 2/9] update textbox & add information --- VRCT.py | 130 +++++++++++++++++++++++++++++++++++++++++++++++--------- 1 file changed, 109 insertions(+), 21 deletions(-) diff --git a/VRCT.py b/VRCT.py index de84a672..d1bb81c5 100644 --- a/VRCT.py +++ b/VRCT.py @@ -4,6 +4,7 @@ import deepl from pythonosc import osc_message_builder from pythonosc import udp_client import customtkinter +from PIL import Image # global PATH_CONFIG = "./config.json" @@ -55,6 +56,65 @@ if AUTH_KEY is not None: customtkinter.set_appearance_mode("System") customtkinter.set_default_color_theme("blue") +class ToplevelWindow_information(customtkinter.CTkToplevel): + def __init__(self, *args, **kwargs): + super().__init__(*args, **kwargs) + self.grid_columnconfigure(0, weight=1) + self.grid_rowconfigure(0, weight=1) + self.geometry(f"{500}x{300}") + # self.resizable(False, False) + + self.title("Information") + # create textbox information + self.textbox_information = customtkinter.CTkTextbox(self) + self.textbox_information.grid(row=0, column=0, padx=(10, 10), pady=(10, 10), sticky="nsew") + textbox_information_message = """VRCT(v0.1b) + +# 概要 +VRChatで使用されるChatBoxをOSC経由でメッセージを送信するツールになります。 +翻訳機能としてDeepLのAPIを使用してメッセージとその翻訳部分を同時に送信することができます。 + +# 使用方法 + 初期設定時 + 1. DeepLのAPIを使用するためにアカウント登録し、認証キーを取得する + 2. configボタンでconfigウィンドウを開きDeepL Auth Keyに認証キーを記載しcheckボタンを押す + 3. configウィンドウを閉じる + + 通常使用時 + 1. メッセージボックスにメッセージを記入 + 2. Enterキーを押し、メッセージを送信する + +# その他の設定 + コンボボックス + 翻訳機能の有効無効 + 翻訳する言語の選択 + + configウィンドウ + OSC IP address: 変更不要 + OSC port: 変更不要 + DeepL Auth key: DeepLの認証キーの設定 + Message Format: 送信するメッセージのデコレーションの設定 + [message]がメッセージボックスに記入したメッセージに置換される + [translation]が翻訳されたメッセージに置換される + 初期フォーマット:"[message]([translation])" + + 設定の初期化 + config.jsonを削除 + +# お問い合わせ +要望などはTwitterまで +https://twitter.com/misya_ai + +# アップデート履歴 +[2023-05-29: v0.1b] v0.1b リリース + +# 注意事項 +再配布とかはやめてね +""" + + self.textbox_information.insert("0.0", textbox_information_message) + self.textbox_information.configure(state='disabled') + class ToplevelWindow_config(customtkinter.CTkToplevel): def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) @@ -146,21 +206,35 @@ class App(customtkinter.CTk): self.sidebar_frame = customtkinter.CTkFrame(self, corner_radius=0) self.sidebar_frame.grid(row=0, column=0, rowspan=4, sticky="nsw") self.sidebar_frame.grid_rowconfigure(4, weight=1) + + # combobox translator self.combobox_translator = customtkinter.CTkComboBox(self.sidebar_frame, command=self.combobox_translator_callback) - self.combobox_translator.grid(row=0, column=0, padx=10, pady=(10, 5), sticky="w") + self.combobox_translator.grid(row=0, column=0, columnspan=2 ,padx=10, pady=(10, 5), sticky="we") + + # combobox language self.combobox_language = customtkinter.CTkComboBox(self.sidebar_frame, command=self.combobox_language_callback) - self.combobox_language.grid(row=1, column=0, padx=10, pady=(5, 10), sticky="w") - self.button_config = customtkinter.CTkButton(self.sidebar_frame, text="config", command=self.open_config) - self.button_config.grid(row=4, column=0, padx=10, pady=(10, 10), sticky="s") + self.combobox_language.grid(row=1, column=0, columnspan=2, padx=10, pady=(5, 10), sticky="we") + + # button information + self.button_information = customtkinter.CTkButton(self.sidebar_frame, text="", width=70, command=self.open_information, + image=customtkinter.CTkImage(Image.open("./img/info-icon-white.png"))) + self.button_information.grid(row=4, column=0, padx=5, pady=(10, 10), sticky="wse") + self.information_window = None + + # button config + self.button_config = customtkinter.CTkButton(self.sidebar_frame, text="", width=70, command=self.open_config, + image=customtkinter.CTkImage(Image.open("./img/config-icon-white.png"))) + self.button_config.grid(row=4, column=1, padx=5, pady=(10, 10), sticky="wse") self.config_window = None - # create textbox - self.textbox = customtkinter.CTkTextbox(self) - self.textbox.grid(row=0, column=1, padx=(10, 10), pady=(10, 5), sticky="nsew") + # create textbox message log + self.textbox_message_log = customtkinter.CTkTextbox(self) + self.textbox_message_log.grid(row=0, column=1, padx=(10, 10), pady=(10, 5), sticky="nsew") + self.textbox_message_log.configure(state='disabled') - # create entry - self.entry = customtkinter.CTkEntry(self, placeholder_text="message") - self.entry.grid(row=1, column=1, columnspan=2, padx=(10, 10), pady=(5, 10), sticky="nsew") + # create entry message box + self.entry_message_box = customtkinter.CTkEntry(self, placeholder_text="message") + self.entry_message_box.grid(row=1, column=1, columnspan=2, padx=(10, 10), pady=(5, 10), sticky="nsew") # set default values self.combobox_translator.configure(values=["DeepL", "Disable"],) @@ -169,20 +243,27 @@ class App(customtkinter.CTk): "ID","IT","KO","LT","LV","NB","NL","PL","PT","PT-BR","PT-PT","RO","RU","SK", "SL","SV","TR","UK","ZH", ],) - self.entry.bind("", self.press_key) + self.entry_message_box.bind("", self.press_key) if TRANSLATOR is None: - self.textbox.insert("0.0", f"Auth Keyを設定してないか間違っています\n") + # error update Auth key + self.textbox_message_log.configure(state='normal') + self.textbox_message_log.insert("0.0", f"Auth Keyを設定してないか間違っています\n") + self.textbox_message_log.configure(state='disabled') self.combobox_language.set(TARGET_LANG) self.combobox_translator.set(CHOICE_TRANSLATOR) - def open_config(self): if self.config_window is None or not self.config_window.winfo_exists(): self.config_window = ToplevelWindow_config(self) self.config_window.focus() + def open_information(self): + if self.information_window is None or not self.information_window.winfo_exists(): + self.information_window = ToplevelWindow_information(self) + self.information_window.focus() + def combobox_translator_callback(self, choice): global CHOICE_TRANSLATOR CHOICE_TRANSLATOR = choice @@ -203,16 +284,19 @@ class App(customtkinter.CTk): def press_key(self, event): if TRANSLATOR is None: - self.textbox.insert("0.0", f"Auth Keyを設定してないか間違っています\n") + # error update Auth key + self.textbox_message_log.configure(state='normal') + self.textbox_message_log.insert("0.0", f"Auth Keyを設定してないか間違っています\n") + self.textbox_message_log.configure(state='disabled') else: - entry = self.entry.get() + message = self.entry_message_box.get() # translate if CHOICE_TRANSLATOR != "Disable": - result = TRANSLATOR.translate_text(entry, target_lang=TARGET_LANG) - chat_message = MESSAGE_FORMAT.replace("[message]", entry).replace("[translation]", result.text) + result = TRANSLATOR.translate_text(message, target_lang=TARGET_LANG) + chat_message = MESSAGE_FORMAT.replace("[message]", message).replace("[translation]", result.text) else: - chat_message = f"{entry}" + chat_message = f"{message}" # send OSC message message = osc_message_builder.OscMessageBuilder(address="/chatbox/input") @@ -223,9 +307,13 @@ class App(customtkinter.CTk): client = udp_client.SimpleUDPClient(OSC_IP_ADDRESS, OSC_PORT) client.send(message) - # delete Entry message - self.textbox.insert("0.0", f"{chat_message}\n") - self.entry.delete(0, customtkinter.END) + # update textbox message log + self.textbox_message_log.configure(state='normal') + self.textbox_message_log.insert("0.0", f"{chat_message}\n") + self.textbox_message_log.configure(state='disabled') + + # delete message in entry message box + self.entry_message_box.delete(0, customtkinter.END) app = App() app.mainloop() \ No newline at end of file From 939870a64a7bb837af8c7aeb965d3fb105c22bb7 Mon Sep 17 00:00:00 2001 From: misyaguziya Date: Tue, 30 May 2023 01:07:19 +0900 Subject: [PATCH 3/9] add checkbox for translation --- VRCT.py | 34 ++++++++++++++++++++++++++++------ 1 file changed, 28 insertions(+), 6 deletions(-) diff --git a/VRCT.py b/VRCT.py index d1bb81c5..39b96b96 100644 --- a/VRCT.py +++ b/VRCT.py @@ -11,6 +11,7 @@ PATH_CONFIG = "./config.json" OSC_IP_ADDRESS = "127.0.0.1" OSC_PORT = 9000 TARGET_LANG = "EN-US" +ENABLE_TRANSLATION = True CHOICE_TRANSLATOR = "DeepL" AUTH_KEY = None TRANSLATOR = None @@ -26,6 +27,8 @@ if os.path.isfile(PATH_CONFIG) is not False: OSC_PORT = config["OSC_PORT"] if "TARGET_LANG" in config.keys(): TARGET_LANG = config["TARGET_LANG"] + if "ENABLE_TRANSLATION" in config.keys(): + ENABLE_TRANSLATION = config["ENABLE_TRANSLATION"] if "CHOICE_TRANSLATOR" in config.keys(): CHOICE_TRANSLATOR = config["CHOICE_TRANSLATOR"] if "AUTH_KEY" in config.keys(): @@ -38,6 +41,7 @@ with open(PATH_CONFIG, 'w') as fp: "OSC_IP_ADDRESS": OSC_IP_ADDRESS, "OSC_PORT": OSC_PORT, "TARGET_LANG": TARGET_LANG, + "ENABLE_TRANSLATION": ENABLE_TRANSLATION, "CHOICE_TRANSLATOR": CHOICE_TRANSLATOR, "AUTH_KEY": AUTH_KEY, "MESSAGE_FORMAT": MESSAGE_FORMAT, @@ -207,23 +211,27 @@ class App(customtkinter.CTk): self.sidebar_frame.grid(row=0, column=0, rowspan=4, sticky="nsw") self.sidebar_frame.grid_rowconfigure(4, weight=1) + # checkbox translation + self.checkbox_translation = customtkinter.CTkCheckBox(self.sidebar_frame, text="translation", onvalue=True, offvalue=False, command=self.checkbox_translation_callback) + self.checkbox_translation.grid(row=0, column=0, columnspan=2 ,padx=10, pady=(10, 5), sticky="we") + # combobox translator self.combobox_translator = customtkinter.CTkComboBox(self.sidebar_frame, command=self.combobox_translator_callback) - self.combobox_translator.grid(row=0, column=0, columnspan=2 ,padx=10, pady=(10, 5), sticky="we") + self.combobox_translator.grid(row=1, column=0, columnspan=2 ,padx=10, pady=(10, 5), sticky="we") # combobox language self.combobox_language = customtkinter.CTkComboBox(self.sidebar_frame, command=self.combobox_language_callback) - self.combobox_language.grid(row=1, column=0, columnspan=2, padx=10, pady=(5, 10), sticky="we") + self.combobox_language.grid(row=2, column=0, columnspan=2, padx=10, pady=(5, 10), sticky="we") # button information self.button_information = customtkinter.CTkButton(self.sidebar_frame, text="", width=70, command=self.open_information, - image=customtkinter.CTkImage(Image.open("./img/info-icon-white.png"))) + image=customtkinter.CTkImage(Image.open("./img/info-icon-white.png"))) self.button_information.grid(row=4, column=0, padx=5, pady=(10, 10), sticky="wse") self.information_window = None # button config self.button_config = customtkinter.CTkButton(self.sidebar_frame, text="", width=70, command=self.open_config, - image=customtkinter.CTkImage(Image.open("./img/config-icon-white.png"))) + image=customtkinter.CTkImage(Image.open("./img/config-icon-white.png"))) self.button_config.grid(row=4, column=1, padx=5, pady=(10, 10), sticky="wse") self.config_window = None @@ -237,7 +245,12 @@ class App(customtkinter.CTk): self.entry_message_box.grid(row=1, column=1, columnspan=2, padx=(10, 10), pady=(5, 10), sticky="nsew") # set default values - self.combobox_translator.configure(values=["DeepL", "Disable"],) + if ENABLE_TRANSLATION: + self.checkbox_translation.select() + else: + self.checkbox_translation.deselect() + + self.combobox_translator.configure(values=["DeepL"],) self.combobox_language.configure(values=[ "JA","BG","CS","DA","DE","EL","EN","EN-US","EN-GB","ES","ET","FI","FR","HU", "ID","IT","KO","LT","LV","NB","NL","PL","PT","PT-BR","PT-PT","RO","RU","SK", @@ -264,6 +277,15 @@ class App(customtkinter.CTk): self.information_window = ToplevelWindow_information(self) self.information_window.focus() + def checkbox_translation_callback(self): + global ENABLE_TRANSLATION + ENABLE_TRANSLATION = self.checkbox_translation.get() + with open(PATH_CONFIG, "r") as fp: + config = json.load(fp) + config["ENABLE_TRANSLATION"] = ENABLE_TRANSLATION + with open(PATH_CONFIG, "w") as fp: + json.dump(config, fp, indent=4) + def combobox_translator_callback(self, choice): global CHOICE_TRANSLATOR CHOICE_TRANSLATOR = choice @@ -292,7 +314,7 @@ class App(customtkinter.CTk): message = self.entry_message_box.get() # translate - if CHOICE_TRANSLATOR != "Disable": + if self.checkbox_translator.get() is True: result = TRANSLATOR.translate_text(message, target_lang=TARGET_LANG) chat_message = MESSAGE_FORMAT.replace("[message]", message).replace("[translation]", result.text) else: From 97b03d07258e52d792b656cbd0deda54cf09e409 Mon Sep 17 00:00:00 2001 From: misyaguziya Date: Tue, 30 May 2023 01:24:37 +0900 Subject: [PATCH 4/9] add iconbitmap --- VRCT.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/VRCT.py b/VRCT.py index 39b96b96..fb4fa493 100644 --- a/VRCT.py +++ b/VRCT.py @@ -68,6 +68,7 @@ class ToplevelWindow_information(customtkinter.CTkToplevel): self.geometry(f"{500}x{300}") # self.resizable(False, False) + self.after(200, lambda: self.iconbitmap("./img/app.ico")) self.title("Information") # create textbox information self.textbox_information = customtkinter.CTkTextbox(self) @@ -125,6 +126,7 @@ class ToplevelWindow_config(customtkinter.CTkToplevel): self.geometry(f"{450}x{160}") self.resizable(False, False) + self.after(200, lambda: self.iconbitmap("./img/app.ico")) self.title("Config") self.label_ip_address = customtkinter.CTkLabel(self, text="OSC IP address:", fg_color="transparent") self.label_ip_address.grid(row=0, column=0, columnspan=1, padx=5, pady=5, sticky="nsew") @@ -200,7 +202,7 @@ class ToplevelWindow_config(customtkinter.CTkToplevel): class App(customtkinter.CTk): def __init__(self): super().__init__() - + self.iconbitmap('./img/app.ico') self.title("VRC ChatBox Translator") self.geometry(f"{400}x{180}") self.grid_columnconfigure(1, weight=1) From 554c71873aa62cab66f4bad9cbfe1845dd8de014 Mon Sep 17 00:00:00 2001 From: misyaguziya Date: Tue, 30 May 2023 01:29:05 +0900 Subject: [PATCH 5/9] bugfix typo --- VRCT.py | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/VRCT.py b/VRCT.py index fb4fa493..4287069b 100644 --- a/VRCT.py +++ b/VRCT.py @@ -316,7 +316,7 @@ class App(customtkinter.CTk): message = self.entry_message_box.get() # translate - if self.checkbox_translator.get() is True: + if self.checkbox_translation.get() is True: result = TRANSLATOR.translate_text(message, target_lang=TARGET_LANG) chat_message = MESSAGE_FORMAT.replace("[message]", message).replace("[translation]", result.text) else: @@ -339,5 +339,6 @@ class App(customtkinter.CTk): # delete message in entry message box self.entry_message_box.delete(0, customtkinter.END) -app = App() -app.mainloop() \ No newline at end of file +if __name__ == "__main__": + app = App() + app.mainloop() \ No newline at end of file From 7b1c12487c9e8516aa092087f6fde0376af5a943 Mon Sep 17 00:00:00 2001 From: misyaguziya Date: Tue, 30 May 2023 01:39:18 +0900 Subject: [PATCH 6/9] update information --- VRCT.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/VRCT.py b/VRCT.py index 4287069b..fbb854bc 100644 --- a/VRCT.py +++ b/VRCT.py @@ -73,7 +73,7 @@ class ToplevelWindow_information(customtkinter.CTkToplevel): # create textbox information self.textbox_information = customtkinter.CTkTextbox(self) self.textbox_information.grid(row=0, column=0, padx=(10, 10), pady=(10, 10), sticky="nsew") - textbox_information_message = """VRCT(v0.1b) + textbox_information_message = """VRCT(v0.2b) # 概要 VRChatで使用されるChatBoxをOSC経由でメッセージを送信するツールになります。 @@ -112,6 +112,8 @@ https://twitter.com/misya_ai # アップデート履歴 [2023-05-29: v0.1b] v0.1b リリース +[2023-05-30: v0.2b] +- 翻訳機能有効無効のチェックボックスを追加 # 注意事項 再配布とかはやめてね From ebb9d20a2a6ec2fbb4dd5be1b32a3c12e9419e9c Mon Sep 17 00:00:00 2001 From: misyaguziya Date: Tue, 30 May 2023 01:41:51 +0900 Subject: [PATCH 7/9] change name VRC ChatBox Translator -> VRCT --- VRCT.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/VRCT.py b/VRCT.py index 4287069b..ce2d477b 100644 --- a/VRCT.py +++ b/VRCT.py @@ -203,7 +203,7 @@ class App(customtkinter.CTk): def __init__(self): super().__init__() self.iconbitmap('./img/app.ico') - self.title("VRC ChatBox Translator") + self.title("VRCT") self.geometry(f"{400}x{180}") self.grid_columnconfigure(1, weight=1) self.grid_rowconfigure(0, weight=1) From 0b0bf988eeba69bf76f5e69ab1e29c9aa17e4a7e Mon Sep 17 00:00:00 2001 From: misyaguziya Date: Tue, 30 May 2023 02:23:11 +0900 Subject: [PATCH 8/9] add checkbox for foreground --- VRCT.py | 43 ++++++++++++++++++++++++++++++++++++------- 1 file changed, 36 insertions(+), 7 deletions(-) diff --git a/VRCT.py b/VRCT.py index ce2d477b..825fd629 100644 --- a/VRCT.py +++ b/VRCT.py @@ -13,6 +13,7 @@ OSC_PORT = 9000 TARGET_LANG = "EN-US" ENABLE_TRANSLATION = True CHOICE_TRANSLATOR = "DeepL" +ENABLE_FOREGROUND = True AUTH_KEY = None TRANSLATOR = None MESSAGE_FORMAT = "[message]([translation])" @@ -31,6 +32,8 @@ if os.path.isfile(PATH_CONFIG) is not False: ENABLE_TRANSLATION = config["ENABLE_TRANSLATION"] if "CHOICE_TRANSLATOR" in config.keys(): CHOICE_TRANSLATOR = config["CHOICE_TRANSLATOR"] + if "ENABLE_FOREGROUND" in config.keys(): + ENABLE_FOREGROUND = config["ENABLE_FOREGROUND"] if "AUTH_KEY" in config.keys(): AUTH_KEY = config["AUTH_KEY"] if "MESSAGE_FORMAT" in config.keys(): @@ -43,6 +46,7 @@ with open(PATH_CONFIG, 'w') as fp: "TARGET_LANG": TARGET_LANG, "ENABLE_TRANSLATION": ENABLE_TRANSLATION, "CHOICE_TRANSLATOR": CHOICE_TRANSLATOR, + "ENABLE_FOREGROUND": ENABLE_FOREGROUND, "AUTH_KEY": AUTH_KEY, "MESSAGE_FORMAT": MESSAGE_FORMAT, } @@ -204,37 +208,41 @@ class App(customtkinter.CTk): super().__init__() self.iconbitmap('./img/app.ico') self.title("VRCT") - self.geometry(f"{400}x{180}") + self.geometry(f"{400}x{190}") self.grid_columnconfigure(1, weight=1) self.grid_rowconfigure(0, weight=1) # sidebar left self.sidebar_frame = customtkinter.CTkFrame(self, corner_radius=0) self.sidebar_frame.grid(row=0, column=0, rowspan=4, sticky="nsw") - self.sidebar_frame.grid_rowconfigure(4, weight=1) + self.sidebar_frame.grid_rowconfigure(5, weight=1) # checkbox translation self.checkbox_translation = customtkinter.CTkCheckBox(self.sidebar_frame, text="translation", onvalue=True, offvalue=False, command=self.checkbox_translation_callback) - self.checkbox_translation.grid(row=0, column=0, columnspan=2 ,padx=10, pady=(10, 5), sticky="we") + self.checkbox_translation.grid(row=0, column=0, columnspan=2 ,padx=10, pady=(5, 5), sticky="we") + + # checkbox foreground + self.checkbox_foreground = customtkinter.CTkCheckBox(self.sidebar_frame, text="foreground", onvalue=True, offvalue=False, command=self.checkbox_foreground_callback) + self.checkbox_foreground.grid(row=1, column=0, columnspan=2 ,padx=10, pady=(5, 5), sticky="we") # combobox translator self.combobox_translator = customtkinter.CTkComboBox(self.sidebar_frame, command=self.combobox_translator_callback) - self.combobox_translator.grid(row=1, column=0, columnspan=2 ,padx=10, pady=(10, 5), sticky="we") + self.combobox_translator.grid(row=2, column=0, columnspan=2 ,padx=10, pady=(5, 5), sticky="we") # combobox language self.combobox_language = customtkinter.CTkComboBox(self.sidebar_frame, command=self.combobox_language_callback) - self.combobox_language.grid(row=2, column=0, columnspan=2, padx=10, pady=(5, 10), sticky="we") + self.combobox_language.grid(row=3, column=0, columnspan=2, padx=10, pady=(5, 5), sticky="we") # button information self.button_information = customtkinter.CTkButton(self.sidebar_frame, text="", width=70, command=self.open_information, image=customtkinter.CTkImage(Image.open("./img/info-icon-white.png"))) - self.button_information.grid(row=4, column=0, padx=5, pady=(10, 10), sticky="wse") + self.button_information.grid(row=5, column=0, padx=5, pady=(10, 10), sticky="wse") self.information_window = None # button config self.button_config = customtkinter.CTkButton(self.sidebar_frame, text="", width=70, command=self.open_config, image=customtkinter.CTkImage(Image.open("./img/config-icon-white.png"))) - self.button_config.grid(row=4, column=1, padx=5, pady=(10, 10), sticky="wse") + self.button_config.grid(row=5, column=1, padx=5, pady=(10, 10), sticky="wse") self.config_window = None # create textbox message log @@ -252,6 +260,13 @@ class App(customtkinter.CTk): else: self.checkbox_translation.deselect() + if ENABLE_FOREGROUND: + self.checkbox_foreground.select() + self.attributes("-topmost", True) + else: + self.checkbox_foreground.deselect() + self.attributes("-topmost", False) + self.combobox_translator.configure(values=["DeepL"],) self.combobox_language.configure(values=[ "JA","BG","CS","DA","DE","EL","EN","EN-US","EN-GB","ES","ET","FI","FR","HU", @@ -306,6 +321,20 @@ class App(customtkinter.CTk): with open(PATH_CONFIG, "w") as fp: json.dump(config, fp, indent=4) + def checkbox_foreground_callback(self): + global ENABLE_FOREGROUND + ENABLE_FOREGROUND = self.checkbox_foreground.get() + with open(PATH_CONFIG, "r") as fp: + config = json.load(fp) + config["ENABLE_FOREGROUND"] = ENABLE_FOREGROUND + with open(PATH_CONFIG, "w") as fp: + json.dump(config, fp, indent=4) + + if ENABLE_FOREGROUND: + self.attributes("-topmost", True) + else: + self.attributes("-topmost", False) + def press_key(self, event): if TRANSLATOR is None: # error update Auth key From 85f14db21f82d2add8c83f945cce109d712153b4 Mon Sep 17 00:00:00 2001 From: misyaguziya Date: Tue, 30 May 2023 02:26:42 +0900 Subject: [PATCH 9/9] update information --- VRCT.py | 1 + 1 file changed, 1 insertion(+) diff --git a/VRCT.py b/VRCT.py index fbb854bc..42d8f88e 100644 --- a/VRCT.py +++ b/VRCT.py @@ -114,6 +114,7 @@ https://twitter.com/misya_ai [2023-05-29: v0.1b] v0.1b リリース [2023-05-30: v0.2b] - 翻訳機能有効無効のチェックボックスを追加 +- 常に最前面の有効無効のチェックボックスを追加 # 注意事項 再配布とかはやめてね