自定义ttk:按钮

问题描述 投票:3回答:1

嗨, 我正在寻找一种方法在我的ttk ::按钮的右角添加一个三角形,如下所示:

enter image description here 有时同一个按钮执行2个命令,我想用这个符号指定给我的用户

tcl tk
1个回答
5
投票

首先你需要图像:

set imgred [image create photo -file redcorner.png]
set imggreen [image create photo -file greencorner.png]

接下来为每种颜色创建一个样式元素:

ttk::style element create Red.Corner.TButton.indicator image $imgred
ttk::style element create Green.Corner.TButton.indicator image $imggreen

现在为两个按钮样式中的每一个创建布局。可以使用检索原始ttk ::按钮布局

ttk::style layout TButton

我们使用它作为模板并添加我们的指标元素。

(编辑:请注意,不同的主题可能有不同的布局。 以下示例适用于“默认”主题。)

ttk::style layout Red.Corner.TButton {
  Button.border -sticky nswe -border 1 -children {
    Button.focus -sticky nswe -children {
      Button.padding -sticky nswe -children {
        Button.label -sticky nswe 
        Red.Corner.TButton.indicator -side right -sticky ne}}}}


ttk::style layout Green.Corner.TButton {
  Button.border -sticky nswe -border 1 -children {
    Button.focus -sticky nswe -children {
      Button.padding -sticky nswe -children {
        Button.label -sticky nswe 
        Green.Corner.TButton.indicator -side right -sticky ne}}}}

现在所有部分都已准备好创建按钮:

ttk::button .b -text hello -style Red.Corner.TButton

要更改指示器颜色,只需使用其他样式重新配置:

.b configure -style Green.Corner.TButton

参考文献:ttk::style

© www.soinside.com 2019 - 2024. All rights reserved.