X-Git-Url: http://git.xonotic.org/?a=blobdiff_plain;f=libs%2Fuilib%2Fuilib.cpp;h=3b169fafc3a3cb6ec14029f0b06a6c925e09c8c7;hb=510800cba3d4e30631dfbb0e3e549df91b1f5644;hp=f6b4d22254247d09900bab88e97c4390b7dd415a;hpb=77a453495e98323b7d7b82c1cf68e67e438f9182;p=xonotic%2Fnetradiant.git diff --git a/libs/uilib/uilib.cpp b/libs/uilib/uilib.cpp index f6b4d222..3b169faf 100644 --- a/libs/uilib/uilib.cpp +++ b/libs/uilib/uilib.cpp @@ -56,6 +56,13 @@ namespace ui { return ::file_dialog(*this, open, title, path, pattern, want_load, want_import, want_save); } + Window::Window(window_type type) + : Window(GTK_WINDOW(gtk_window_new( + type == window_type::TOP ? GTK_WINDOW_TOPLEVEL : + type == window_type::POPUP ? GTK_WINDOW_POPUP : + GTK_WINDOW_TOPLEVEL))) + { }; + Window Window::create_dialog_window(const char *title, void func(), void *data, int default_w, int default_h) { return Window(::create_dialog_window(*this, title, func, data, default_w, default_h)); @@ -73,33 +80,117 @@ namespace ui { std::uint64_t Window::on_key_press(bool (*f)(Widget widget, ui_evkey *event, void *extra), void *extra) { - auto pass = std::make_tuple(f, extra); - auto func = [](ui_widget *widget, GdkEventKey *event, void *pass_) -> bool { - using pass_t = decltype(pass); - auto &args = *(pass_t *) pass_; - auto func = std::get<0>(args); - auto pass = std::get<1>(args); - return func(Widget(widget), event, pass); + using f_t = decltype(f); + struct user_data { + f_t f; + void *extra; + } *pass = new user_data{f, extra}; + auto dtor = [](user_data *data, GClosure *) { + delete data; + }; + auto func = [](ui_widget *widget, GdkEventKey *event, user_data *args) -> bool { + return args->f(Widget(widget), event, args->extra); }; - return g_signal_connect(G_OBJECT(*this), "key-press-event", (GCallback) +func, &pass); + auto clos = g_cclosure_new(G_CALLBACK(+func), pass, reinterpret_cast(+dtor)); + return g_signal_connect_closure(G_OBJECT(*this), "key-press-event", clos, false); } + AccelGroup::AccelGroup() : AccelGroup(GTK_ACCEL_GROUP(gtk_accel_group_new())) + { } + + Adjustment::Adjustment(double value, + double lower, double upper, + double step_increment, double page_increment, + double page_size) + : Adjustment( + GTK_ADJUSTMENT(gtk_adjustment_new(value, lower, upper, step_increment, page_increment, page_size))) + { } + Alignment::Alignment(float xalign, float yalign, float xscale, float yscale) : Alignment(GTK_ALIGNMENT(gtk_alignment_new(xalign, yalign, xscale, yscale))) { } + Button::Button() : Button(GTK_BUTTON(gtk_button_new())) + { } + Button::Button(const char *label) : Button(GTK_BUTTON(gtk_button_new_with_label(label))) { } + CellRendererText::CellRendererText() : CellRendererText(GTK_CELL_RENDERER_TEXT(gtk_cell_renderer_text_new())) + { } + + ComboBox ComboBoxText() + { return ComboBox(GTK_COMBO_BOX(gtk_combo_box_new_text())); } + CheckButton::CheckButton(const char *label) : CheckButton(GTK_CHECK_BUTTON(gtk_check_button_new_with_label(label))) { } + Entry::Entry() : Entry(GTK_ENTRY(gtk_entry_new())) + { } + + Entry::Entry(std::size_t max_length) : Entry(GTK_ENTRY(gtk_entry_new_with_max_length(max_length))) + { } + + Frame::Frame(const char *label) : Frame(GTK_FRAME(gtk_frame_new(label))) + { } + + HBox::HBox(bool homogenous, int spacing) : HBox(GTK_HBOX(gtk_hbox_new(homogenous, spacing))) + { } + + Image::Image() : Image(GTK_IMAGE(gtk_image_new())) + { } + Label::Label(const char *label) : Label(GTK_LABEL(gtk_label_new(label))) { } + Menu::Menu() : Menu(GTK_MENU(gtk_menu_new())) + { } + + MenuItem::MenuItem(const char *label, bool mnemonic) : MenuItem( + GTK_MENU_ITEM((mnemonic ? gtk_menu_item_new_with_mnemonic : gtk_menu_item_new_with_label)(label))) + { } + + HPaned::HPaned() : HPaned(GTK_HPANED(gtk_hpaned_new())) + { } + + VPaned::VPaned() : VPaned(GTK_VPANED(gtk_vpaned_new())) + { } + + ScrolledWindow::ScrolledWindow() : ScrolledWindow(GTK_SCROLLED_WINDOW(gtk_scrolled_window_new(nullptr, nullptr))) + { } + + SpinButton::SpinButton(Adjustment adjustment, double climb_rate, std::size_t digits) : SpinButton( + GTK_SPIN_BUTTON(gtk_spin_button_new(adjustment, climb_rate, digits))) + { } + + Table::Table(std::size_t rows, std::size_t columns, bool homogenous) : Table( + GTK_TABLE(gtk_table_new(rows, columns, homogenous))) + { } + + TextView::TextView() : TextView(GTK_TEXT_VIEW(gtk_text_view_new())) + { } + + TreePath::TreePath() : TreePath(gtk_tree_path_new()) + { } + + TreePath::TreePath(const char *path) : TreePath(gtk_tree_path_new_from_string(path)) + { } + + TreeView::TreeView() : TreeView(GTK_TREE_VIEW(gtk_tree_view_new())) + { } + TreeView::TreeView(TreeModel model) : TreeView(GTK_TREE_VIEW(gtk_tree_view_new_with_model(model))) { } + TreeViewColumn::TreeViewColumn(const char *title, CellRenderer renderer, + std::initializer_list attributes) + : TreeViewColumn(gtk_tree_view_column_new_with_attributes(title, renderer, nullptr)) + { + for (auto &it : attributes) { + gtk_tree_view_column_add_attribute(*this, renderer, it.attribute, it.column); + } + }; + VBox::VBox(bool homogenous, int spacing) : VBox(GTK_VBOX(gtk_vbox_new(homogenous, spacing))) { }