postgresql データベースと対話する非常に単純な GUI があります。メインフレームは 4 つの象限に分割され、各象限には 4 つのエントリ ウィジェットがあります。1 つの象限のコード例を次に示します。
my $f_blue = $bottom_half->Frame(-bg=>'BLUE')-> pack(-side=>'left', -expand=>1, -fill=>'both');
$f_blue->Label(-text=>'BLUE', -bg=>'blue', -fg=>'white')->pack(-side=>'top');
my $blue_table = $f_blue->Table(-rows => 3,
-columns => 3,
-fixedrows => 1,
-fixedcolumns => 1,
-scrollbars => 'oo',
-relief => 'raised') -> pack(-side => 'top', -expand => 1, -fill=>'both');
$blue_table -> put(1,1,
$blue_table->Label(-text => 'Cs-137:'));
my $t_blue_cs137 = $blue_table->Entry(-selectbackground=>"blueviolet");
$blue_table -> put(1,2,$t_blue_cs137);
$blue_table -> put(1,3,
$blue_table->Label(-text => 'MBq'));
$blue_table -> put(2,1,
$blue_table->Label(-text => 'Tc-99m:'));
my $t_blue_tc99m = $blue_table->Entry(-selectbackground=>"blueviolet");
$blue_table -> put(2,2,$t_blue_tc99m);
$blue_table -> put(2,3,
$blue_table->Label(-text => 'MBq:'));
$blue_table -> put(3,1,
$blue_table->Label(-text => 'Tl-201:'));
my $t_blue_tl201 = $blue_table->Entry(-selectbackground=>"blueviolet");
$blue_table -> put(3,2,$t_blue_tl201);
$blue_table -> put(3,3,
$blue_table->Label(-text => 'MBq:'));
GUI を使用してデータを入力するとき、タブで次のエントリにスキップできません。ループして設定できるようにキーバインディングを設定する方法はありますか
`$t_blue_cs137` to be active
PRESS TAB
`$t_blue_tc99m` NOW ACTIVE
PRESS TAB
`$t_blue_tl201` NOW ACTIVE
PRESS TAB
Do the same with the next quadrant
`$t_red_cs137` in frame $f_red NOW ACTIVE
perlTKでこれを行う方法はありますか
私は次のことを試しました
$f_blue->bindtags( [ ($f_blue->bindtags)[$t_blue_cs137,$t_blue_tc99m,$t_blue_tl201] ] );
# fix the bindtags order so that widget events are
# processed before class events
$f_blue->bind("<Tab>", sub { $f_blue->focusNext; Tk->break; });
ただし、これにより、各サブフレームと GUI のボタンの間でのみタブを使用できます。