你的设计相当复杂。我不使用 wxFormbuilder,我喜欢通过“硬编码”布局手动设置表单。
所以在我解释我会怎么做之前,这里有一些建议:
- 我会将确定/取消/帮助栏放在其他地方(在单独的 wxPanel 中,然后将它们放在最后的对话框中)
- 我会移动确定/取消/帮助栏上的测试连接按钮。
- 就设置布局而言,测试连接按钮目前处于一个糟糕的位置
- (可选)我会在名称/主机/数据库和用户名/密码之间拆分表单,因为它们代表一些您可以在其他地方重用的子单元
现在这是我将如何构建表单。我让你实现 getValue 和 setValue。此外,您需要为工具栏(使用 a wxBoxSizer
)做类似的事情并将它们放在一起(wxBoxSizer
再次使用 a )。
此外,如果您可能想使用wxStaticBox
class ConnectionEditor
: wxPanel
{
public:
ConnectionEditor(wxWindow* parent);
//
void getValue(ConnectionSettings&);
void setValue(ConnectionSettings const&);
private:
wxTextCtrl* name_;
wxTextCtrl* host_;
wxTextCtrl* database_;
wxTextCtrl* username_;
wxTextCtrl* password_;
wxCheckBox* save_password_;
};
wxTextCtrl* CreateTextControl(wxWindow* parent)
{
return new wxTextCtrl(parent, wxID_ANY, wxEmptyString, wxDefaultPosition, wxSize(100, 20));
}
wxTextCtrl* CreateStaticText(wxWindow* parent, std::string const& text)
{
return new wxStaticText(parent, wxID_ANY, text.c_str());
}
ConnectionEditor::ConnectionEditor(wxWindow* parent)
: wxPanel(parent, wxID_ANY)
{
this->name_ = CreateTextControl(this);
this->host_ = CreateTextControl(this);
this->database_ = CreateTextControl(this);
this->username_ = CreateTextControl(this);
this->password_ = CreateTextControl(this);
this->save_password_ = new wxCheckBox(this, wxID_ANY, "on");
//
wxFlexGridSizer* sizer = new wxFlexGridSizer(6, 2, 5, ,5); // 6 rows, 2 cols, 5 spacing in between
//
sizer->Add(CreateStaticText(this, "Name"));
sizer->Add(this->name_);
sizer->Add(CreateStaticText(this, "Host"));
sizer->Add(this->host_);
sizer->Add(CreateStaticText(this, "Database"));
sizer->Add(this->database_);
sizer->Add(CreateStaticText(this, "Username"));
sizer->Add(this->username_);
sizer->Add(CreateStaticText(this, "Password"));
sizer->Add(this->password_);
sizer->Add(CreateStaticText(this, "Save Password"));
sizer->Add(this->save_password_);
//
this->SetSizerAndFit(sizer);
}