🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Tkinter

Tkinterは、GUIツールキットである“Tk”をPythonから利用できるようにした標準ライブラリである。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

3505閲覧

tkinter画像の位置変更

cheese-

総合スコア3

Tkinter

Tkinterは、GUIツールキットである“Tk”をPythonから利用できるようにした標準ライブラリである。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/01/16 14:57

画像の位置を指定の場所にしたいのですが表示されません

python

1import tkinter as tk 2from PIL import ImageTk, Image 3 4class Application(tk.Frame): 5 6 def __init__(self,master): 7 super().__init__(master) 8 self.pack() 9 10 self.width=950 11 self.height=500 12 13 master.geometry(str(self.width)+"x"+str(self.height)) #ウィンドウの作成 14 15 master.title("画像表示") #タイトル 16 self.master.config(bg="#CCFFCC") #ウィンドウの背景色 17 18 self.createWidgets() #ウィジェットの作成 19 20 def createWidgets(self): #ウィジェットの作成 21 # 画像読み込み 22 read_image = Image.open('パス') 23 24 # canvas作成 25 self.test_canvas = tk.Canvas(self, width=read_image.width, height=read_image.height) 26 self.test_canvas.place(x=100, y=50) 27 28 # canvasに画像を表示 29 im = ImageTk.PhotoImage(image=read_image) 30 self.test_canvas.photo = im 31 self.test_canvas.create_image(0,0, anchor='nw', image=self.test_canvas.photo) 32def main(): 33 win = tk.Tk() 34 win.resizable(width=True, height=True) 35 app = Application(master=win) 36 app.mainloop() 37 38if __name__ == "__main__": 39 main() 40 41

↑だと画像が表示されません

python

1 # canvas作成 2 self.test_canvas = tk.Canvas(self, width=read_image.width, height=read_image.height) 3 self.test_canvas.pack()

↑こちらのコードに変えると指定の画像は表示されるのですが表示する位置を変更することができません
(x=100, y=50) に画像を表示したいです

回答よろしくお願いします

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

単に画像の配置位置を (100, 50) にしたいのであれば

Python

1 # canvas作成 2 #self.test_canvas = tk.Canvas(self, width=read_image.width, height=read_image.height) 3 #self.test_canvas.place(x=100, y=50) 4 self.test_canvas = tk.Canvas(self, width=self.width, height=self.height) 5 self.test_canvas.pack() 6 7 # canvasに画像を表示 8 im = ImageTk.PhotoImage(image=read_image) 9 self.test_canvas.photo = im 10 #self.test_canvas.create_image(0,0, anchor='nw', image=self.test_canvas.photo) 11 self.test_canvas.create_image(100,50, anchor='nw', image=self.test_canvas.photo)

本当に canvas の配置位置を (100, 50) にしたいのであれば

Python

1 ... 2 #self.createWidgets() #ウィジェットの作成 3 self.createWidgets(master) #ウィジェットの作成 4 #def createWidgets(self): #ウィジェットの作成 5 def createWidgets(self, master): #ウィジェットの作成 6 # 画像読み込み 7 read_image = Image.open('パス') 8 #self.test_canvas = tk.Canvas(self, width=read_image.width, height=read_image.height) 9 self.test_canvas = tk.Canvas(master, width=read_image.width, height=read_image.height) 10 self.test_canvas.place(x=100, y=50)

投稿2021/01/17 02:27

lehshell

総合スコア1156

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

cheese-

2021/01/17 13:48

大変分かりやすい回答ありがとうございました
guest

0

ベストアンサー

place() でキャンバスを配置した場合、親ウィジェットのFrameにサイズが伝わらない為
キャンバスを配置する為のFrameのサイズが小さくなり、キャンバス自体が見えなくなっています。

レイアウトを伸縮可能にすることで解消できるはずです。
以下はpack()を使った例。コードは適切な場所に書いてください。

python

1# フレームのレイアウト 2self.pack(fill=tk.BOTH, expand=tk.YES) 3 4# キャンバスのレイアウト 5canvas.pack(fill=tk.BOTH, expand=tk.YES) 6 7# 画像の配置位置 8canvas.create_image(x座標, y座標, image=im)

もう一点、create_image の最初の引数が 0, 0 だと、画像の中心の座標が左上(0, 0)になり
画像の右下1/4 しか見えなくなってしまいます。

表示位置は、画像サイズから中心座標を求め、計算してください。
x, y = im.width()//2 + 100, im.height()//2 + 50

投稿2021/01/17 01:43

teamikl

総合スコア8740

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

cheese-

2021/01/17 13:49

分かりやすく説明して下さりありがとうございました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問