「Qtのコントロール - タブ」の版間の差分
ナビゲーションに移動
検索に移動
(同じ利用者による、間の2版が非表示) | |||
1行目: | 1行目: | ||
== 概要 == | == 概要 == | ||
Qtにおいて、<code>QTabWidget</code>クラスを使用してタブをコントロールする手順を記載する。<br> | |||
<br><br> | <br><br> | ||
135行目: | 135行目: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<br><br> | <br><br> | ||
{{#seo: | |||
|title={{PAGENAME}} : Exploring Electronics and SUSE Linux | MochiuWiki | |||
|keywords=MochiuWiki,Mochiu,Wiki,Mochiu Wiki,Electric Circuit,Electric,pcb,Mathematics,AVR,TI,STMicro,AVR,ATmega,MSP430,STM,Arduino,Xilinx,FPGA,Verilog,HDL,PinePhone,Pine Phone,Raspberry,Raspberry Pi,C,C++,C#,Qt,Qml,MFC,Shell,Bash,Zsh,Fish,SUSE,SLE,Suse Enterprise,Suse Linux,openSUSE,open SUSE,Leap,Linux,uCLnux,Podman,電気回路,電子回路,基板,プリント基板 | |||
|description={{PAGENAME}} - 電子回路とSUSE Linuxに関する情報 | This page is {{PAGENAME}} in our wiki about electronic circuits and SUSE Linux | |||
|image=/resources/assets/MochiuLogo_Single_Blue.png | |||
}} | |||
__FORCETOC__ | __FORCETOC__ | ||
[[カテゴリ:Qt]] | [[カテゴリ:Qt]] |
2024年10月14日 (月) 11:05時点における最新版
概要
Qtにおいて、QTabWidget
クラスを使用してタブをコントロールする手順を記載する。
タブ幅を揃える(等幅にする)
タブを追加すると、タブに表示するテキストの文字列長に応じて、自動的にタブ幅が調整される。
全てのタブ幅を等幅にするには、QTabBar::tabSizeHint
メソッドをオーバーライドして、適切なQSize
クラスを指定することで実現できる。
QTabBar
クラスを継承した派生クラスをQTabWidget
クラスに設定するには、QTabWidget::setTabBar
メソッドを使用すればよいが、
QTabWidget::setTabBar
メソッドはprotected
であるため、QTabWidget
クラスを継承した派生クラスも作成する必要がある。
以下の例では、QTabBar
クラスを継承したQTabBarExクラス、QTabWidget
クラスを継承したQTabWidgetExクラスを作成している。
また、Qt Designerにおいて、タブコントロールを右クリックして[格上げ先を指定]を選択後、QTabWidgetExクラスに格上げすること。
// MainWindow.cpp
#include "MainWindow.h"
#include "ui_MainWindow.h"
MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow)
{
ui->setupUi(this);
}
MainWindow::~MainWindow()
{
delete ui;
}
// MainWindow.h
#pragma once
#include <QMainWindow>
namespace Ui {class MainWindow;}
class MainWindow : public QMainWindow
{
Q_OBJECT
public:
explicit MainWindow(QWidget *parent = nullptr);
~MainWindow();
private:
Ui::MainWindow *ui;
};
// QTabBarEx.cpp
QTabBarEx::QTabBarEx(QWidget *parent) : QTabBar(parent)
{
}
QSize QTabBarEx::tabSizeHint(int index) const
{
QSize size = QTabBar::tabSizeHint(index);
// QSizeクラスのコンストラクタの第1引数がタブ幅、第2引数がタブの高さとなる
return QSize(100, size.height());
}
// QTabBarEx.h
#pragma once
#include <QTabBar>
class QTabBarEx : public QTabBar
{
public:
explicit QTabBarEx(QWidget *parent = Q_NULLPTR);
~QTabBarEx() override {}
protected:
QSize tabSizeHint(int) const override;
};
// QTabWidgetEx.cpp
#include <memory>
#include "QTabWidgetEx.h"
QTabWidgetEx::QTabWidgetEx(QWidget *parent) : QTabWidget(parent)
{
std::unique_ptr<QTabBarEx> newTabBar = std::make_unique<QTabBarEx>(this);
// QTabWidgetのソースコード(qtabwidget.cppファイルの237〜238行目)を参考にしている
newTabBar->setObjectName(QLatin1String("qt_tabwidget_tabbar"));
newTabBar->setDrawBase(false);
setTabBar(newTabBar);
}
// QTabWidgetEx.h
#include <QTabWidget>
#include "QTabBarEx.h"
class QTabWidgetEx : public QTabWidget
{
public:
explicit QTabWidgetEx(QWidget *parent = Q_NULLPTR);
~QTabWidgetEx() {}
};
任意のタブに閉じるボタンを表示しない
全てのタブに[閉じる]ボタンを表示する場合、以下の2つの方法がある。
- Qt Designerで設定する場合
- プロパティ[tabsClosable]にチェックを入力する。
- ソースコードで設定する場合
- 以下のように記述する。
ui->tabWidget->setTabsClosable(true);
任意のタブに[閉じる]ボタンを表示しない場合、ソースコードに以下を記述する。
setTabButton
メソッドの第1引数には、タブのインデックス(0オリジン)を指定する。
QTabBar *tabBar = ui->tabWidget->tabBar();
tabBar->setTabButton(0,
static_cast<QTabBar::ButtonPosition>(tabBar->style()->styleHint(QStyle::SH_TabBar_CloseButtonPosition, nullptr, tabBar)),
nullptr);