【发布时间】:2020-05-21 00:29:27
【问题描述】:
我一直在为我为工作编写的脚本开发一个 GUI,并且通过一些研究,我已经能够创建带有图像的按钮,以便于识别。我唯一的问题是,现在图像和文本都锚定在按钮的中间,这使它笨拙,中间没有空格。
我想做的是将图像对齐到按钮的左侧,将文本对齐到右侧。有没有办法在 tkinter 中做到这一点?
这是我的用户界面代码:
def create_interface(self)->None:
ph_plan = ImageTk.PhotoImage(Image.open(self.plan_image))
ph_bmi = ImageTk.PhotoImage(Image.open(self.bm_image))
ph_calc = ImageTk.PhotoImage(Image.open(self.calc_image))
ph_plot = ImageTk.PhotoImage(Image.open(self.plot_image))
top = tk.Frame(self.root).grid(row=1)
middle = tk.Frame(self.root).grid(row=2, pady=40)
bottom = tk.Frame(self.root).grid(row=3, pady=80)
# Create buttons
bmi_btn = Button(top, text='Blastmaster Inputs', width=self.button_width,
image=ph_bmi, compound='left', bg='#f2fafc',
font=('Helvetica', 12, 'bold'), command=self.get_bm_inputs)
plan_btn = Button(top, text='Weekly Plan', bg='#f2fafc', font=('Helvetica', 12, 'bold'),
image=ph_plan, compound='left', width=self.button_width,
command=self.get_plan_output)
calc_btn = Button(bottom, text='Calculate sampling', height=80, width=self.button_width,
bg='#f2fafc', font=('Helvetica', 12, 'bold'), image=ph_calc,
compound='left', command=self.calculate_sampling)
self.plot_btn = Button(bottom, text='Create plots', height=80, width=self.button_width,
bg='#f2fafc', font=('Helvetica', 12, 'bold'), state='disabled',
image=ph_plot, compound='left', command=self.create_forecast_plots)
# Place buttons into window
bmi_btn.grid(row=1, column=1, pady=20)
plan_btn.grid(row=1, column=2, pady=20)
calc_btn.grid(row=4, column=1)
self.plot_btn.grid(row=4, column=2)
# Create references to image to protect from garbage collector
self.plot_btn.image = ph_plot
bmi_btn.image = ph_bmi
plan_btn.image = ph_plan
calc_btn.image = ph_calc
# Create labels
label_text1 = 'Enter start date for the forecast'
label_text2 = 'Enter end date for the forecast'
Label(middle, text=label_text1, font='Hevetica').grid(row=2, column=1)
Label(middle, text=label_text2, font='Helvetica').grid(row=3, column=1)
# Create and place data entry fields
self.start = Entry(middle, width=38)
self.start.grid(row=2, column=2)
self.end = Entry(middle, width=38)
self.end.grid(row=3, column=2)
【问题讨论】:
-
您已经使用
compound='left'选项完成了这项工作。 -
@acw1668 但
compound='left'只确保图像出现在文本的左侧,但如果可能的话,我真正需要的是图像和文本之间的空间。 -
尝试设置
padx,它会在图像/文本和边框之间以及文本和图像之间添加空间。或者在文本的开头添加空格。 -
@acw1668,天哪!在文本的开头添加空格可以解决问题。现在我自己都想不出来,感觉很尴尬哈哈。
标签: python user-interface tkinter