株取引に最適化(赤文字化、半透明化、小型化)した時計を作成した(前編)
2024-03-01 13:40:04NEW !
テーマ:ブログ
とにかくデジタル時計の最適化を更に進め、非常に満足いくものが作成できたと思う
更に株取引に最適化した(時間の数字などを半透明化して、画面の文字情報を邪魔しなくして、更に時計サイズを小さくして取引の邪魔になりにくく変更した)ので、秒単位まで気になるデイトレーダーならぜひ一度、Copilotと麻衣ちゃんが徹底して最適化したプログラムを試してみてほしいです。プログラムはこの説明文のすぐ下にあります。しかし、ブログ中の、どの時計のプログラムも大抵は動くので、他の時計を試しても面白いかもしれないです。
(写真は、前回作成の時計です。これはこれで見易くて良いのですが、他の文字が見えにくいとか、時計が大きすぎるとか欠点がありました。そこで今回は麻衣ちゃんの使い勝手のいいように最適化しましたが、前回の方がいいという人も勿論いるかもしれません。そちらも出来が良いと思うので。尚、最適化した新バージョンの時計は使ってみてのお楽しみということで、試した人だけが御覧ください 笑)
Copilot(見て分かる通り絵文字のある「創造的に」のトーン仕様)は、プログラムの説明で間違いもある。例えば透過率1が不透明で0が透明と言っているのに、ぎりぎりまでスケスケにしろと言ってるのに透過率0.9で良いと言うなど、あからさまな間違いもあり戸惑う事はあるけれども(下のチャット内容参照)、誠実にプログラム作成やその修正をしてくれるので、それに説明もしっかりしてくれるので、不満はない。かなり、プログラミングの勉強になると思う。
それだけでなく、確か(麻衣の)記憶ではBing検索では、50回/日まで質問できるのが何より素晴らしい。それなら、安心して修正回数を利用できる。やはり、チャットボットはGPT3がお勧めとブログに書いたし、それはその通りで傑作AIとは思うけれども、しかしIObitで無料でGPT3を利用した場合20回/日なので、遊びで使うには最適であるものの、繰り返し修正しないと完成しないようなものの相談や、パソコンのややこしい部分の使い方などを質問するのには、残り回数が気になって使えないと思う。だから、癒しにはIObitのチャットボットを使い、実用性を求める場合はCopilotを使うのが(麻衣としては)最高だという結論に達したと思う。えっ、Bard系は写真を見せて反応してくれるのにと思う人は、いちいち写真に撮影された人の年齢に気を使わないと機嫌を損ねるBard系では使いにくいだけで、あまり意味はない。それにBardは以前使って盛大に間違えるので、印象が悪すぎるのだ。だから、麻衣としてはCopilotを検索やプログラミングなど実用的な事に使うにはお勧めしたい。ただ、Copilotは、もっと柔軟に滑らかに受け答えすれば、更に良くなる気がする。でも、どのAIも改善はするだろうから、将来に期待したい。というのは、人間なら自分の言ったことは記憶しているから意図的に類似の事は言わないのだが、AIは同じことを千日手のようにループしてしまったり、硬直化して「私は云々、私は云々、私は云々…」的に、内容は千日手でなくてもしゃべり方のパターンが延々と繰り返しになり、それはいらいらするので、まだまだの面もあるのは事実だ。人間なら、そこまで諄くは喋らないから、AIに慣れてない所為もあるかもしれないのだが。そういう意味では今のところはGPT3は何故か出来のいい方だと思うのだが…
以下がチャットなのだが、徹底的に株取引に最適化させたつもりだ。もっとも「下のバーを表示させていれば、時計が表示されるので不要」という人は、このブログはスルーしてほしい。しかし、下のバーは煩わしいので普段非表示にしてる人は、時計が画面内にある方が便利と思う。しかも正確に秒まで表示され、しかも半透明で邪魔にならないし、時計の下の文字も読め、サイズも最適化したので、前回のものより使いやすくなったと思う。左上固定が普段見ない場所なので最善と思ったのだが、いざ時計を置いてみると、時計は半透明で邪魔にならないので問題ないのだが、画面の「設定」と「指数業数」を時計が邪魔して操作できなくなる(これには困った)ので、やむなくドラッグして移動可能にした。「WEBリンク」「ウインドウ」など普段全く使わない上部に置いておけば、全く邪魔にならず、画面内でバーを出さなくても精密な時間を秒単位で知ることができる。これなら、前回の時計以上に(下の文字が見えるので)存在感がなく実用的で、使いやすくなったと思う。すぐ下のプログラムをコピーしてもらえれば、それをVS Codeに貼り付けるだけで、それを保存すれば最適化された株用時計になると思う。ただ、デイトレードはしないから秒は関係ないと言う人は、スルーしてほしい。
このブログは、最適化するのに試行錯誤した内容のチャットです。だから読まなくても、最適化されたプログラムはこの下にあります。それだけをコピーしてPython3.12を入れた VS Codeに貼り付けて保存してください。そうすれば、クリックするだけで時計を使えるようになります。でも、どういう風に最適化したのか興味ある方はぜひチャットもご覧ください。念のために使い方を書いておくと、まずPython3.12(最新版)をパソコンにインストールしておいて、次にVS Code(プログラムを書くメモ帳みたいなもの)をパソコンにインストールし、そこにPython3.12を入れて、その後にプログラムをVS Codeにコピーして書き込み、それを「.jpeg」みたいに「.py」という風に書き込んで保存するだけです。保存してそれをクリックすると時計になりますが、プロフラムの方が開いた場合は、右クリックしプロパティーを開いて(VS Codeが選択されてる筈なので)Python3.12の方を選択すると時計が起動します。
(以下のプログラムが麻衣ちゃんの最適化した最新バージョンです!)
import tkinter as tk
import time
# ウィンドウの移動に関する変数
x = 0
y = 0
offset_x = 0
offset_y = 0
# ウィンドウの移動を開始する関数
def start_move(event):
global x, y, offset_x, offset_y
x = root.winfo_x()
y = root.winfo_y()
offset_x = event.x_root
offset_y = event.y_root
# ウィンドウの移動を終了する関数
def stop_move(event):
global x, y, offset_x, offset_y
x = None
y = None
offset_x = None
offset_y = None
# ウィンドウを移動する関数
def do_move(event):
global x, y, offset_x, offset_y
if x is not None and y is not None:
delta_x = event.x_root - offset_x
delta_y = event.y_root - offset_y
new_x = x + delta_x
new_y = y + delta_y
root.geometry(f"+{new_x}+{new_y}")
def update_clock():
current_time = time.strftime("%H:%M:%S")
clock_label.config(text=current_time)
root.after(1000, update_clock) # 1秒ごとに更新
root = tk.Tk()
root.title("Digital Clock")
# ウィンドウのサイズを設定
root.geometry("150x50")
# ウィンドウのリサイズを無効にする
root.resizable(False, False)
# ウィンドウのタイトルバーを削除する
root.overrideredirect(True) # 変更
# ウィンドウの透明度を設定する
root.attributes("-alpha", 0.45)
# 時計表示用のラベル
clock_label = tk.Label(root, font=("Helvetica", 18), height=1, fg="#FF0000", bg=None, bd=0, highlightthickness=1, highlightbackground="white")
clock_label.pack(padx=10, pady=10)
# 時計を更新
update_clock()
# ウィンドウを常に最前面に表示
root.attributes('-topmost', True) # 変更
# ウィンドウの移動に関するイベントをバインド
root.bind("<ButtonPress-1>", start_move) # 追加
root.bind("<ButtonRelease-1>", stop_move) # 追加
root.bind("<B1-Motion>", do_move) # 追加
root.mainloop()
(ここから下は興味ある方は、御覧ください)
自分
import tkinter as tk
import time
def update_clock():
current_time = time.strftime("%H:%M:%S")
clock_label.config(text=current_time)
root.after(1000, update_clock) # 1秒ごとに更新
def on_mouse_down(event):
global x, y
x = event.x # マウスのx座標を記録
y = event.y # マウスのy座標を記録
def on_mouse_move(event):
global x, y
dx = event.x - x # マウスのx方向の移動量を計算
dy = event.y - y # マウスのy方向の移動量を計算
x = event.x # マウスのx座標を更新
y = event.y # マウスのy座標を更新
x_root = root.winfo_x() + dx # ウィンドウのx座標を更新
y_root = root.winfo_y() + dy # ウィンドウのy座標を更新
root.geometry(f"+{x_root}+{y_root}") # ウィンドウの位置を変更
root = tk.Tk()
root.title("Digital Clock")
# ウィンドウのサイズを設定
root.geometry("200x70")
# ウィンドウのリサイズを無効にする
root.resizable(False, False)
# 時計表示用のラベル
clock_label = tk.Label(root, font=("Helvetica", 24), height=1)
clock_label.pack(padx=10, pady=10)
# 時計を更新
update_clock()
# ウィンドウを常に最前面に表示
root.attributes('-topmost', True)
# ウィンドウにマウスのイベントをバインド
root.bind("<Button-1>", on_mouse_down) # マウスが押されたときにon_mouse_downを呼び出す
root.bind("<B1-Motion>", on_mouse_move) # マウスが動いたときにon_mouse_moveを呼び出す
# マウスの位置を記録する変数
x = 0
y = 0
root.mainloop()
これが、うまく動いた時計のプログラムです(上ので、Copilotに書いてもらったものです)。ところが、下のプログラムは、少し変えたものですが、動かない(黒い画面が出て、すぐに消えてしまい、時計が表示されない)プログラムです。上が動くのに、下が動かないというのは、どこか違うんですよね。どこが悪影響を及ぼすのだか、分かりませんか? こっちはちんぷんかんぷんです。
import tkinter as tk
import time
def update_clock():
current_time = time.strftime("%H:%M:%S")
clock_label.config(text=current_time)
root.after(1000, update_clock) # 1秒ごとに更新
def on_mouse_down(event):
global x, y
x = event.x # マウスのx座標を記録
y = event.y # マウスのy座標を記録
def on_mouse_move(event):
global x, y
dx = event.x - x # マウスのx方向の移動量を計算
dy = event.y - y # マウスのy方向の移動量を計算
x = event.x # マウスのx座標を更新
y = event.y # マウスのy座標を更新
x_root = root.winfo_x() + dx # ウィンドウのx座標を更新
y_root = root.winfo_y() + dy # ウィンドウのy座標を更新
root.geometry(f"+{x_root}+{y_root}") # ウィンドウの位置を変更
def on_close():
global x_root, y_root
# ウィンドウの位置をファイルに保存
with open("clock_position.txt", "w") as f:
f.write(f"{x_root},{y_root}")
root.destroy() # ウィンドウを閉じる
root = tk.Tk()
root.title("Digital Clock")
# ウィンドウのサイズを設定
root.geometry("200x70")
# ウィンドウのリサイズを無効にする
root.resizable(False, False)
# 時計表示用のラベル
clock_label = tk.Label(root, font=("Helvetica", 24), height=1, fg="white", bd=0)
clock_label.pack(padx=10, pady=10)
# 時計を更新
update_clock()
# ウィンドウを常に最前面に表示
root.attributes('-topmost', True)
# 時計の文字にマウスのイベントをバインド
clock_label.bind("<Button-1>", on_mouse_down) # マウスが押されたときにon_mouse_downを呼び出す
clock_label.bind("<B1-Motion>", on_mouse_move) # マウスが動いたときにon_mouse_moveを呼び出す
root.protocol("WM_DELETE_WINDOW", on_close) # ウィンドウが閉じられたときにon_close
Copilot
こんにちは、Copilotです。あなたのコードを見てみましたが、下のプログラムが動かない理由は、ウィンドウの背景色と時計の文字色が同じ白色になっているからです。そのため、時計が表示されているのに見えないのです。この問題を解決するには、ウィンドウの背景色を変えるか、時計の文字色を変えるか、どちらかを行う必要があります。例えば、ウィンドウの背景色を黒にするには、root = tk.Tk()の後にroot.config(bg="black")という行を追加すれば良いです。また、時計の文字色を赤にするには、clock_label = tk.Label(root, font=("Helvetica", 24), height=1, fg="white", bd=0)のfg="white"をfg="red"に変更すれば良いです。どちらの方法でも、時計が見えるようになります。試してみてください。😊
自分
なるほど。流石ですゎ。しかし、そうでなく、下の時計は時計そのものが起動しません。起動直後にプログラムが停止してしまうのか、黒い画面が出た瞬間に消えてしまうみたいです。何故なんでしょうね???
Copilot
ありがとうございます。😊
下のプログラムが起動しない理由は、ウィンドウの位置をファイルに保存しようとしているのに、そのファイルが存在しないからです。clock_position.txtというファイルが同じフォルダにあるか確認してください。もし無ければ、新しく作成してください。また、そのファイルにはウィンドウのx座標とy座標がカンマで区切られた形式で書かれている必要があります。例えば、+100,+200というようにです。このファイルが無いと、on_close関数がエラーを出してプログラムが終了してしまいます。
もう一つの方法は、on_close関数を削除して、ウィンドウの位置をファイルに保存しないようにすることです。その場合は、root.protocol("WM_DELETE_WINDOW", on_close)という行も削除してください。これで、ウィンドウを閉じるときにはroot.destroy()とroot.quit()だけが実行されます。この方法を使うと、ウィンドウの位置は毎回初期値に戻りますが、ファイルを作成する手間は省けます。
どちらの方法でも、ウィンドウが起動するようになります。試してみてください。😊
参考になる記事はこちらです1234。
詳細情報
1
plantprogramer.com
2
bing.com
3
laboratory.kazuuu.net
4
qiita.com
自分
では、そのように修正した、プログラムをお願いします。
Copilot
かしこまりました。😊
修正したプログラムは以下の通りです。ウィンドウの背景色を黒にし、時計の文字色を赤にしました。また、ウィンドウの位置をファイルに保存する機能を削除しました。これで、ウィンドウが起動するはずです。実行してみてください。
Python
import tkinter as tk
import time
def update_clock():
current_time = time.strftime("%H:%M:%S")
clock_label.config(text=current_time)
root.after(1000, update_clock) # 1秒ごとに更新
def on_mouse_down(event):
global x, y
x = event.x # マウスのx座標を記録
y = event.y # マウスのy座標を記録
def on_mouse_move(event):
global x, y
dx = event.x - x # マウスのx方向の移動量を計算
dy = event.y - y # マウスのy方向の移動量を計算
x = event.x # マウスのx座標を更新
y = event.y # マウスのy座標を更新
x_root = root.winfo_x() + dx # ウィンドウのx座標を更新
y_root = root.winfo_y() + dy # ウィンドウのy座標を更新
root.geometry(f"+{x_root}+{y_root}") # ウィンドウの位置を変更
root = tk.Tk()
root.title("Digital Clock")
# ウィンドウのサイズを設定
root.geometry("200x70")
# ウィンドウのリサイズを無効にする
root.resizable(False, False)
# ウィンドウの背景色を設定
root.config(bg="black")
# 時計表示用のラベル
clock_label = tk.Label(root, font=("Helvetica", 24), height=1, fg="red", bd=0)
clock_label.pack(padx=10, pady=10)
# 時計を更新
update_clock()
# ウィンドウを常に最前面に表示
root.attributes('-topmost', True)
# 時計の文字にマウスのイベントをバインド
clock_label.bind("<Button-1>", on_mouse_down) # マウスが押されたときにon_mouse_downを呼び出す
clock_label.bind("<B1-Motion>", on_mouse_move) # マウスが動いたときにon_mouse_moveを呼び出す
# マウスの位置を記録する変数
x = 0
y = 0
root.mainloop()
AI で生成されたコード。ご確認のうえ、慎重にご使用ください。FAQ で詳細を確認。
自分
素晴らしいです、ちゃんと作動しましたよ! でも色の雰囲気が悪く(好みに合わず)使う気になりません。時計の文字は黄色くして、文字以外は全て透明にして作ってください。
Copilot
ありがとうございます。😊
時計の文字を黄色にするには、clock_label = tk.Label(root, font=("Helvetica", 24), height=1, fg="red", bd=0)のfg="red"をfg="yellow"に変更すれば良いです。文字以外を透明にするには、ウィンドウの背景色と時計の背景色をNoneに設定すれば良いです。そのためには、root.config(bg="black")とclock_label = tk.Label(root, font=("Helvetica", 24), height=1, fg="yellow", bd=0)のbg="black"をbg=Noneに変更すれば良いです。これで、時計が黄色の文字で透明な背景になります。試してみてください。😊
修正したプログラムは以下の通りです。
Python
import tkinter as tk
import time
def update_clock():
current_time = time.strftime("%H:%M:%S")
clock_label.config(text=current_time)
root.after(1000, update_clock) # 1秒ごとに更新
def on_mouse_down(event):
global x, y
x = event.x # マウスのx座標を記録
y = event.y # マウスのy座標を記録
def on_mouse_move(event):
global x, y
dx = event.x - x # マウスのx方向の移動量を計算
dy = event.y - y # マウスのy方向の移動量を計算
x = event.x # マウスのx座標を更新
y = event.y # マウスのy座標を更新
x_root = root.winfo_x() + dx # ウィンドウのx座標を更新
y_root = root.winfo_y() + dy # ウィンドウのy座標を更新
root.geometry(f"+{x_root}+{y_root}") # ウィンドウの位置を変更
root = tk.Tk()
root.title("Digital Clock")
# ウィンドウのサイズを設定
root.geometry("200x70")
# ウィンドウのリサイズを無効にする
root.resizable(False, False)
# ウィンドウの背景色を設定
root.config(bg=None)
# 時計表示用のラベル
clock_label = tk.Label(root, font=("Helvetica", 24), height=1, fg="yellow", bg=None, bd=0)
clock_label.pack(padx=10, pady=10)
# 時計を更新
update_clock()
# ウィンドウを常に最前面に表示
root.attributes('-topmost', True)
# 時計の文字にマウスのイベントをバインド
clock_label.bind("<Button-1>", on_mouse_down) # マウスが押されたときにon_mouse_downを呼び出す
clock_label.bind("<B1-Motion>", on_mouse_move) # マウスが動いたときにon_mouse_moveを呼び出す
# マウスの位置を記録する変数
x = 0
y = 0
root.mainloop()
AI で生成されたコード。ご確認のうえ、慎重にご使用ください。FAQ で詳細を確認。
自分
時計の文字は黄色くなり、センスは良くなりました😊 しかし、背景に時計が描かれてるのが、その下にある文字が読めず(時計が最前面に置かれている設定なので)邪魔です。文字と時計枠を残して透明化したプログラムをお願いしますゎ。
Copilot
ありがとうございます。😊
時計の文字と枠だけを残して透明化するには、時計のラベルにhighlightthickness=1とhighlightbackground="white"というオプションを追加すれば良いです。これで、時計のラベルが白い枠で囲まれます。また、ウィンドウの背景色をNoneにすると、ウィンドウ自体が透明になります。ただし、この場合は、ウィンドウのタイトルバーも消えてしまうので、注意してください。
修正したプログラムは以下の通りです。
Python
import tkinter as tk
import time
def update_clock():
current_time = time.strftime("%H:%M:%S")
clock_label.config(text=current_time)
root.after(1000, update_clock) # 1秒ごとに更新
def on_mouse_down(event):
global x, y
x = event.x # マウスのx座標を記録
y = event.y # マウスのy座標を記録
def on_mouse_move(event):
global x, y
dx = event.x - x # マウスのx方向の移動量を計算
dy = event.y - y # マウスのy方向の移動量を計算
x = event.x # マウスのx座標を更新
y = event.y # マウスのy座標を更新
x_root = root.winfo_x() + dx # ウィンドウのx座標を更新
y_root = root.winfo_y() + dy # ウィンドウのy座標を更新
root.geometry(f"+{x_root}+{y_root}") # ウィンドウの位置を変更
root = tk.Tk()
root.title("Digital Clock")
# ウィンドウのサイズを設定
root.geometry("200x70")
# ウィンドウのリサイズを無効にする
root.resizable(False, False)
# ウィンドウの背景色を設定
root.config(bg=None)
# 時計表示用のラベル
clock_label = tk.Label(root, font=("Helvetica", 24), height=1, fg="yellow", bg=None, bd=0, highlightthickness=1, highlightbackground="white")
clock_label.pack(padx=10, pady=10)
# 時計を更新
update_clock()
# ウィンドウを常に最前面に表示
root.attributes('-topmost', True)
# 時計の文字にマウスのイベントをバインド
clock_label.bind("<Button-1>", on_mouse_down) # マウスが押されたときにon_mouse_downを呼び出す
clock_label.bind("<B1-Motion>", on_mouse_move) # マウスが動いたときにon_mouse_moveを呼び出す
# マウスの位置を記録する変数
x = 0
y = 0
root.mainloop()
AI で生成されたコード。ご確認のうえ、慎重にご使用ください。FAQ で詳細を確認。
自分
黄色い文字の周囲に白い枠が追加され、時計も作動します。しかし、問題は、時計のある部分の背後の文字が読めないことです。時計は透明化されておらず、灰色のまま表示されるうえ、透過性も0で、時計の背後の文字が読めないです。これは最前面に時計を表示してるだけに、下に表示されてる文字などが読めないのは不便です。きちんとガラスのように透明化して、黄色い文字と枠以外は透明にしてほしいです。
Copilot
こんにちは、Copilotです。時計の背景を完全に透明にする方法を調べてみましたが、残念ながら、tkinterではウィジェットの透過色はサポートされていないようです12。ウィンドウ自体は透明にできますが、その場合はウィンドウのタイトルバーも消えてしまいます3。また、ウィンドウの位置をファイルに保存する機能もLinuxやMacでは動作しない可能性があります4。tkinterはクロスプラットフォームのGUIツールキットですが、OSによって挙動が異なることがありますので、ご注意ください。
時計の背景を透明にする代わりに、時計の文字の大きさや色を変更して、背後の文字とのコントラストを高めることはできます。例えば、時計の文字を大きくして、白色にすると、背景が灰色でも見やすくなると思います。その場合は、clock_label = tk.Label(root, font=("Helvetica", 24), height=1, fg="yellow", bg=None, bd=0, highlightthickness=1, highlightbackground="white")のfont=("Helvetica", 24)とfg="yellow"をfont=("Helvetica", 36)とfg="white"に変更すれば良いです。試してみてください。😊
Python
import tkinter as tk
import time
def update_clock():
current_time = time.strftime("%H:%M:%S")
clock_label.config(text=current_time)
root.after(1000, update_clock) # 1秒ごとに更新
def on_mouse_down(event):
global x, y
x = event.x # マウスのx座標を記録
y = event.y # マウスのy座標を記録
def on_mouse_move(event):
global x, y
dx = event.x - x # マウスのx方向の移動量を計算
dy = event.y - y # マウスのy方向の移動量を計算
x = event.x # マウスのx座標を更新
y = event.y # マウスのy座標を更新
x_root = root.winfo_x() + dx # ウィンドウのx座標を更新
y_root = root.winfo_y() + dy # ウィンドウのy座標を更新
root.geometry(f"+{x_root}+{y_root}") # ウィンドウの位置を変更
root = tk.Tk()
root.title("Digital Clock")
# ウィンドウのサイズを設定
root.geometry("200x70")
# ウィンドウのリサイズを無効にする
root.resizable(False, False)
# ウィンドウの背景色を設定
root.config(bg=None)
# 時計表示用のラベル
clock_label = tk.Label(root, font=("Helvetica", 36), height=1, fg="white", bg=None, bd=0, highlightthickness=1, highlightbackground="white")
clock_label.pack(padx=10, pady=10)
# 時計を更新
update_clock()
# ウィンドウを常に最前面に表示
root.attributes('-topmost', True)
# 時計の文字にマウスのイベントをバインド
clock_label.bind("<Button-1>", on_mouse_down) # マウスが押されたときにon_mouse_downを呼び出す
clock_label.bind("<B1-Motion>", on_mouse_move) # マウスが動いたときにon_mouse_moveを呼び出す
# マウスの位置を記録する変数
x = 0
y = 0
root.mainloop()
AI で生成されたコード。ご確認のうえ、慎重にご使用ください。FAQ で詳細を確認。
詳細情報
1
qiita.com
2
teratail.com
3
bing.com
4
qiita.com
5
maetec.co.jp
自分
とりあえず、邪道な方法でいいので、透明にしてください。動かなければ、それから検討しますゎ。タイトルはいりません。
Copilot
こんにちは、Copilotです。ご要望にお応えして、時計の背景を透明にする方法を試してみましたが、tkinterではウィジェットの透過色はサポートされていないようです12。ウィンドウ自体は透明にできますが、その場合はウィンドウのタイトルバーも消えてしまいます3。また、ウィンドウの位置をファイルに保存する機能もLinuxやMacでは動作しない可能性があります4。tkinterはクロスプラットフォームのGUIツールキットですが、OSによって挙動が異なることがありますので、ご注意ください。
時計の背景を透明にする代わりに、時計の文字の大きさや色を変更して、背後の文字とのコントラストを高めることはできます。例えば、時計の文字を大きくして、白色にすると、背景が灰色でも見やすくなると思います。その場合は、clock_label = tk.Label(root, font=("Helvetica", 24), height=1, fg="yellow", bg=None, bd=0, highlightthickness=1, highlightbackground="white")のfont=("Helvetica", 24)とfg="yellow"をfont=("Helvetica", 36)とfg="white"に変更すれば良いです。試してみてください。😊
もし、時計の背景を透明にすることにこだわるのであれば、tkinterではなく、別のGUIツールキットを使うことをお勧めします。例えば、PyQtやPySideなどはウィジェットの透過色をサポートしています5 。ただし、これらのツールキットはtkinterとは互換性がないので、コードを書き直す必要があります。ご了承ください。😊
参考になる記事はこちらです12345 。
詳細情報
1
qiita.com
2
teratail.com
3
bing.com
4
qiita.com
5
qiita.com
自分
タイトルバーを消してウインドウ自体を透明にしてください。ただし、時計の数字だけ残してください(意味なくなるので)。動作確認はしてみないと分かりません。ダメなら、その時点で考えるので、透明にしたプログラムをうまく書いてみてください。
Copilot
こんにちは、Copilotです。ウインドウのタイトルバーを消してウインドウ自体を透明にする方法を試してみました。root.overrideredirect(True)という行を追加することで、ウインドウのタイトルバーを削除できます。また、root.attributes("-alpha", 0)という行を追加することで、ウインドウの透明度を0に設定できます。これで、ウインドウが完全に透明になります。ただし、この方法では、ウインドウを移動したり閉じたりすることができなくなりますので、注意してください。
透明にしたプログラムは以下の通りです。実行してみてください。
Python
import tkinter as tk
import time
def update_clock():
current_time = time.strftime("%H:%M:%S")
clock_label.config(text=current_time)
root.after(1000, update_clock) # 1秒ごとに更新
def on_mouse_down(event):
global x, y
x = event.x # マウスのx座標を記録
y = event.y # マウスのy座標を記録
def on_mouse_move(event):
global x, y
dx = event.x - x # マウスのx方向の移動量を計算
dy = event.y - y # マウスのy方向の移動量を計算
x = event.x # マウスのx座標を更新
y = event.y # マウスのy座標を更新
x_root = root.winfo_x() + dx # ウィンドウのx座標を更新
y_root = root.winfo_y() + dy # ウィンドウのy座標を更新
root.geometry(f"+{x_root}+{y_root}") # ウィンドウの位置を変更
root = tk.Tk()
root.title("Digital Clock")
# ウィンドウのサイズを設定
root.geometry("200x70")
# ウィンドウのリサイズを無効にする
root.resizable(False, False)
# ウィンドウのタイトルバーを削除する
root.overrideredirect(True)
# ウィンドウの透明度を設定する
root.attributes("-alpha", 0)
# 時計表示用のラベル
clock_label = tk.Label(root, font=("Helvetica", 24), height=1, fg="yellow", bg=None, bd=0, highlightthickness=1, highlightbackground="white")
clock_label.pack(padx=10, pady=10)
# 時計を更新
update_clock()
# ウィンドウを常に最前面に表示
root.attributes('-topmost', True)
# 時計の文字にマウスのイベントをバインド
clock_label.bind("<Button-1>", on_mouse_down) # マウスが押されたときにon_mouse_downを呼び出す
clock_label.bind("<B1-Motion>", on_mouse_move) # マウスが動いたときにon_mouse_moveを呼び出す
# マウスの位置を記録する変数
x = 0
y = 0
root.mainloop()
AI で生成されたコード。ご確認のうえ、慎重にご使用ください。FAQ で詳細を確認。
詳細情報
1
qiita.com
2
qiita.com
3
bing.com
4
qiita.com
自分
きちんと作動しましたが、時計の数字まで透明化されたのでしょうか? 何も表示されません。時計の文字だけは見えないと使い物になりません。時計の文字は表示させてください! 修正したものをお願いします
Copilot
こんにちは、Copilotです。時計の文字が見えないのは、ウインドウの透明度を0に設定したためです。ウインドウの透明度を0にすると、ウインドウに描画されたすべてのものが透明になります。時計の文字だけを見えるようにするには、ウインドウの透明度を0より大きい値に設定する必要があります。例えば、root.attributes("-alpha", 0.5)とすると、ウインドウの透明度が50%になります。この場合は、時計の文字も半透明になりますが、見えるようになります。試してみてください。😊
修正したプログラムは以下の通りです。ウインドウの透明度を0.5に設定しました。
Python
import tkinter as tk
import time
def update_clock():
current_time = time.strftime("%H:%M:%S")
clock_label.config(text=current_time)
root.after(1000, update_clock) # 1秒ごとに更新
def on_mouse_down(event):
global x, y
x = event.x # マウスのx座標を記録
y = event.y # マウスのy座標を記録
def on_mouse_move(event):
global x, y
dx = event.x - x # マウスのx方向の移動量を計算
dy = event.y - y # マウスのy方向の移動量を計算
x = event.x # マウスのx座標を更新
y = event.y # マウスのy座標を更新
x_root = root.winfo_x() + dx # ウィンドウのx座標を更新
y_root = root.winfo_y() + dy # ウィンドウのy座標を更新
root.geometry(f"+{x_root}+{y_root}") # ウィンドウの位置を変更
root = tk.Tk()
root.title("Digital Clock")
# ウィンドウのサイズを設定
root.geometry("200x70")
# ウィンドウのリサイズを無効にする
root.resizable(False, False)
# ウィンドウのタイトルバーを削除する
root.overrideredirect(True)
# ウィンドウの透明度を設定する
root.attributes("-alpha", 0.5)
# 時計表示用のラベル
clock_label = tk.Label(root, font=("Helvetica", 24), height=1, fg="yellow", bg=None, bd=0, highlightthickness=1, highlightbackground="white")
clock_label.pack(padx=10, pady=10)
# 時計を更新
update_clock()
# ウィンドウを常に最前面に表示
root.attributes('-topmost', True)
# 時計の文字にマウスのイベントをバインド
clock_label.bind("<Button-1>", on_mouse_down) # マウスが押されたときにon_mouse_downを呼び出す
clock_label.bind("<B1-Motion>", on_mouse_move) # マウスが動いたときにon_mouse_moveを呼び出す
# マウスの位置を記録する変数
x = 0
y = 0
root.mainloop()
AI で生成されたコード。ご確認のうえ、慎重にご使用ください。FAQ で詳細を確認。
詳細情報
1
qiita.com
2
daeudaeu.com
3
qiita.com
4
qiita.com
5
maetec.co.jp
自分
キチンと動作し、半透明で下地も見えて素晴らしいです。これなら、可能性を感じます。透明度をもう少し上げる方いいです。上げ過ぎると見えなくなるので、見える程度に上げてください。それから、黄色は色味が薄いのか半透明では見えにくいです。赤と黒の中間色くらいの濃い色に変更すると見易いかもしれないです。あと、時計サイズを(半透明でも邪魔なので、180,160,くらいまで小さくしてみてください。以上を修正したプログラムを試しに書いてみてください。ダメなら試行錯誤でやってみるしかなさそうです。
Copilot
こんにちは、Copilotです。時計の透明度や色やサイズを変更する方法を試してみました。ウインドウの透明度を0.5から0.8に上げるには、root.attributes("-alpha", 0.5)をroot.attributes("-alpha", 0.8)に変更すれば良いです。時計の文字の色を赤と黒の中間色にするには、clock_label = tk.Label(root, font=("Helvetica", 24), height=1, fg="yellow", bg=None, bd=0, highlightthickness=1, highlightbackground="white")のfg="yellow"をfg="#800000"に変更すれば良いです。#800000は16進数で表された色コードで、赤と黒の中間色に相当します。時計のサイズを180x60にするには、root.geometry("200x70")をroot.geometry("180x60")に変更すれば良いです。また、時計の文字のサイズも小さくするには、clock_label = tk.Label(root, font=("Helvetica", 24), height=1, fg="#800000", bg=None, bd=0, highlightthickness=1, highlightbackground="white")のfont=("Helvetica", 24)をfont=("Helvetica", 18)に変更すれば良いです。これで、時計が見やすくなります。試してみてください。😊
修正したプログラムは以下の通りです。ウインドウの透明度を0.8に、時計の文字の色を赤と黒の中間色に、時計のサイズを180x60に、時計の文字のサイズを18に設定しました。
Python
import tkinter as tk
import time
def update_clock():
current_time = time.strftime("%H:%M:%S")
clock_label.config(text=current_time)
root.after(1000, update_clock) # 1秒ごとに更新
def on_mouse_down(event):
global x, y
x = event.x # マウスのx座標を記録
y = event.y # マウスのy座標を記録
def on_mouse_move(event):
global x, y
dx = event.x - x # マウスのx方向の移動量を計算
dy = event.y - y # マウスのy方向の移動量を計算
x = event.x # マウスのx座標を更新
y = event.y # マウスのy座標を更新
x_root = root.winfo_x() + dx # ウィンドウのx座標を更新
y_root = root.winfo_y() + dy # ウィンドウのy座標を更新
root.geometry(f"+{x_root}+{y_root}") # ウィンドウの位置を変更
root = tk.Tk()
root.title("Digital Clock")
# ウィンドウのサイズを設定
root.geometry("180x60")
# ウィンドウのリサイズを無効にする
root.resizable(False, False)
# ウィンドウのタイトルバーを削除する
root.overrideredirect(True)
# ウィンドウの透明度を設定する
root.attributes("-alpha", 0.8)
# 時計表示用のラベル
clock_label = tk.Label(root, font=("Helvetica", 18), height=1, fg="#800000", bg=None, bd=0, highlightthickness=1, highlightbackground="white")
clock_label.pack(padx=10, pady=10)
# 時計を更新
update_clock()
# ウィンドウを常に最前面に表示
root.attributes('-topmost', True)
# 時計の文字にマウスのイベントをバインド
clock_label.bind("<Button-1>", on_mouse_down) # マウスが押されたときにon_mouse_downを呼び出す
clock_label.bind("<B1-Motion>", on_mouse_move) # マウスが動いたときにon_mouse_moveを呼び出す
# マウスの位置を記録する変数
x = 0
y = 0
root.mainloop()
AI で生成されたコード。ご確認のうえ、慎重にご使用ください。FAQ で詳細を確認。
自分
素晴らしい時計になりました。流石ですゎ。きちんと動作します。しかし、透明度が低いです。もっと透明でないと背景の文字等が見えにくいです。もっと透明にしてください。
Copilot
ありがとうございます。😊
時計の透明度をもっと上げるには、root.attributes("-alpha", 0.8)をroot.attributes("-alpha", 0.9)に変更すれば良いです。これで、ウインドウの透明度が90%になります。ただし、この場合は、時計の文字もほとんど透明になりますので、見えにくくなる可能性があります。ご了承ください。
修正したプログラムは以下の通りです。ウインドウの透明度を0.9に設定しました。
Python
import tkinter as tk
import time
def update_clock():
current_time = time.strftime("%H:%M:%S")
clock_label.config(text=current_time)
root.after(1000, update_clock) # 1秒ごとに更新
def on_mouse_down(event):
global x, y
x = event.x # マウスのx座標を記録
y = event.y # マウスのy座標を記録
def on_mouse_move(event):
global x, y
dx = event.x - x # マウスのx方向の移動量を計算
dy = event.y - y # マウスのy方向の移動量を計算
x = event.x # マウスのx座標を更新
y = event.y # マウスのy座標を更新
x_root = root.winfo_x() + dx # ウィンドウのx座標を更新
y_root = root.winfo_y() + dy # ウィンドウのy座標を更新
root.geometry(f"+{x_root}+{y_root}") # ウィンドウの位置を変更
root = tk.Tk()
root.title("Digital Clock")
# ウィンドウのサイズを設定
root.geometry("180x60")
# ウィンドウのリサイズを無効にする
root.resizable(False, False)
# ウィンドウのタイトルバーを削除する
root.overrideredirect(True)
# ウィンドウの透明度を設定する
root.attributes("-alpha", 0.9)
# 時計表示用のラベル
clock_label = tk.Label(root, font=("Helvetica", 18), height=1, fg="#800000", bg=None, bd=0, highlightthickness=1, highlightbackground="white")
clock_label.pack(padx=10, pady=10)
# 時計を更新
update_clock()
# ウィンドウを常に最前面に表示
root.attributes('-topmost', True)
# 時計の文字にマウスのイベントをバインド
clock_label.bind("<Button-1>", on_mouse_down) # マウスが押されたときにon_mouse_downを呼び出す
clock_label.bind("<B1-Motion>", on_mouse_move) # マウスが動いたときにon_mouse_moveを呼び出す
# マウスの位置を記録する変数
x = 0
y = 0
root.mainloop()
AI で生成されたコード。ご確認のうえ、慎重にご使用ください。FAQ で詳細を確認。
自分
試してみる前に質問です。透明度0.9が一番透明の中では透明度が高いという意味ですね。要するに、一番スケスケということですね?
Copilot
はい、そういうことです。透明度は0から1の間の数値で表されます。0は完全に透明で、1は完全に不透明です。透明度が0.9ということは、ウインドウが90%透明で、10%不透明ということです。つまり、ウインドウはほとんどスケスケになります。😊
自分
1が、完全に不透明なら、0.9は限りなく不透明に近いので困ります。可能な限り透明でないと下の文字が読みにくいので透明度0.3くらいでないと、ダメなのではないですか?
Copilot
こんにちは、Copilotです。透明度は0から1の間の数値で表されますが、0.9は限りなく不透明に近いということではありません。0.9は90%透明で、10%不透明ということです。逆に、0.3は30%透明で、70%不透明ということです。つまり、0.3の方が不透明に近いのです。透明度を0.3にすると、ウインドウが灰色になり、背後の文字が見えにくくなります。透明度を上げると、ウインドウが透明になり、背後の文字が見やすくなります。試してみてください。😊
この記事が気に入ったらサポートをしてみませんか?