Toplevel which can contain other widgets

See: https://developer.gnome.org/gtk3/stable/GtkWindow.html

Introduced properties

fun activate_default: Bool

gtk :: GtkWindow :: activate_default

Activates the default widget for the window
fun activate_focus: Bool

gtk :: GtkWindow :: activate_focus

Activates the current focused widget within the window.
fun connect_destroy_signal_to_quit

gtk :: GtkWindow :: connect_destroy_signal_to_quit

Connect the "destroy" signal to quit_gtk
fun decorated=(setting: Bool)

gtk :: GtkWindow :: decorated=

Try to convince the window manage to decorate or not this window
fun default_size(width: Int, height: Int)

gtk :: GtkWindow :: default_size

Windows can't actually be 0x0 in size, they must be at least 1x1
fun gravity=(window_grav: GdkGravity)

gtk :: GtkWindow :: gravity=

fun has_toplevel_focus: Bool

gtk :: GtkWindow :: has_toplevel_focus

Returns whether the input focus is within this GtkWindow. For real toplevel windows, this is identical to gtk_window_is_active(), but for embedded windows, like GtkPlug, the results will differ.
fun keep_above=(setting: Bool)

gtk :: GtkWindow :: keep_above=

fun keep_below=(setting: Bool)

gtk :: GtkWindow :: keep_below=

fun modal=(is_modal: Bool)

gtk :: GtkWindow :: modal=

Sets a window modal or non-modal. Modal windows prevent interaction with other windows in the same application.
fun on_close(to_call: GtkCallable, user_data: nullable Object)

gtk :: GtkWindow :: on_close

The "destroy" signal is emitted when a widget is destroyed, either by explicitly calling gtk_widget_destroy() or when the widget is unparented. Top-level GtkWindows are also destroyed when the Close window control button is clicked.
fun resizable=(is_resizable: Bool)

gtk :: GtkWindow :: resizable=

fun resize(width: Int, height: Int)

gtk :: GtkWindow :: resize

Resize the window as if the user had done so
fun set_focus(widget: GtkWidget)

gtk :: GtkWindow :: set_focus

fun title=(title: String)

gtk :: GtkWindow :: title=

fun titlebar=(widget: GtkWidget)

gtk :: GtkWindow :: titlebar=

Redefined properties

redef type SELF: GtkWindow

gtk $ GtkWindow :: SELF

Type of this instance, automatically specialized in every class

All properties

fun !=(other: nullable Object): Bool

core :: Object :: !=

Have self and other different values?
fun ==(other: nullable Object): Bool

core :: Object :: ==

Have self and other the same value?
type CLASS: Class[SELF]

core :: Object :: CLASS

The type of the class of self.
type SELF: Object

core :: Object :: SELF

Type of this instance, automatically specialized in every class
fun activate_default: Bool

gtk :: GtkWindow :: activate_default

Activates the default widget for the window
fun activate_focus: Bool

gtk :: GtkWindow :: activate_focus

Activates the current focused widget within the window.
fun add(widget: GtkWidget)

gtk :: GtkContainer :: add

Add a widget to the container
fun address_is_null: Bool

core :: Pointer :: address_is_null

Is the address behind this Object at NULL?
fun bg_color=(state: GtkStateType, color: GdkRGBA)

gtk :: GtkWidget :: bg_color=

protected fun class_factory(name: String): CLASS

core :: Object :: class_factory

Implementation used by get_class to create the specific class.
fun class_name: String

core :: Object :: class_name

The class name of the object.
fun connect_destroy_signal_to_quit

gtk :: GtkWindow :: connect_destroy_signal_to_quit

Connect the "destroy" signal to quit_gtk
fun decorated=(setting: Bool)

gtk :: GtkWindow :: decorated=

Try to convince the window manage to decorate or not this window
fun default_size(width: Int, height: Int)

gtk :: GtkWindow :: default_size

Windows can't actually be 0x0 in size, they must be at least 1x1
fun destroy

gtk :: GtkWidget :: destroy

Destroy the widget
fun fg_color=(state: GtkStateType, color: GdkRGBA)

gtk :: GtkWidget :: fg_color=

with gtk it's possible to set fg_color to all widget: is it correct? is fg color inherited?
fun free

core :: Pointer :: free

Free the memory pointed by this pointer
fun get_class: CLASS

core :: Object :: get_class

The meta-object representing the dynamic type of self.
fun gravity=(window_grav: GdkGravity)

gtk :: GtkWindow :: gravity=

fun halign=(value: GtkAlign)

gtk :: GtkWidget :: halign=

Horizontal alignement of this widget
fun has_toplevel_focus: Bool

gtk :: GtkWindow :: has_toplevel_focus

Returns whether the input focus is within this GtkWindow. For real toplevel windows, this is identical to gtk_window_is_active(), but for embedded windows, like GtkPlug, the results will differ.
fun hash: Int

core :: Object :: hash

The hash code of the object.
fun hide

gtk :: GtkWidget :: hide

Hide the widget (reverse the effects of show)
init init

core :: Object :: init

fun inspect: String

core :: Object :: inspect

Developer readable representation of self.
protected fun inspect_head: String

core :: Object :: inspect_head

Return "CLASSNAME:#OBJECTID".
intern fun is_same_instance(other: nullable Object): Bool

core :: Object :: is_same_instance

Return true if self and other are the same instance (i.e. same identity).
fun is_same_serialized(other: nullable Object): Bool

core :: Object :: is_same_serialized

Is self the same as other in a serialization context?
intern fun is_same_type(other: Object): Bool

core :: Object :: is_same_type

Return true if self and other have the same dynamic type.
fun keep_above=(setting: Bool)

gtk :: GtkWindow :: keep_above=

fun keep_below=(setting: Bool)

gtk :: GtkWindow :: keep_below=

fun modal=(is_modal: Bool)

gtk :: GtkWindow :: modal=

Sets a window modal or non-modal. Modal windows prevent interaction with other windows in the same application.
init nul: Pointer

core :: Pointer :: nul

C NULL pointer
intern fun object_id: Int

core :: Object :: object_id

An internal hash code for the object based on its identity.
fun on_close(to_call: GtkCallable, user_data: nullable Object)

gtk :: GtkWindow :: on_close

The "destroy" signal is emitted when a widget is destroyed, either by explicitly calling gtk_widget_destroy() or when the widget is unparented. Top-level GtkWindows are also destroyed when the Close window control button is clicked.
fun output

core :: Object :: output

Display self on stdout (debug only).
intern fun output_class_name

core :: Object :: output_class_name

Display class name on stdout (debug only).
fun remove(widget: GtkWidget)

gtk :: GtkContainer :: remove

Remove the widget from the container
fun resizable=(is_resizable: Bool)

gtk :: GtkWindow :: resizable=

fun resize(width: Int, height: Int)

gtk :: GtkWindow :: resize

Resize the window as if the user had done so
fun resize_mode: GtkResizeMode

gtk :: GtkContainer :: resize_mode

Get the resize mode of the container
fun resize_mode=(resize_mode: GtkResizeMode)

gtk :: GtkContainer :: resize_mode=

Set the resize mode of the container
fun sensitive: Bool

gtk :: GtkWidget :: sensitive

return the sensitivity of the widget
fun sensitive=(sensitive: Bool)

gtk :: GtkWidget :: sensitive=

Sets the sensitivity of a widget. sensitive -> the user can interact with it.
fun serialization_hash: Int

core :: Object :: serialization_hash

Hash value use for serialization
fun set_focus(widget: GtkWidget)

gtk :: GtkWindow :: set_focus

fun set_size_request(width: Int, height: Int)

gtk :: GtkWidget :: set_size_request

Set the minimum dimension of this widget
fun show

gtk :: GtkWidget :: show

Show the widget on screen
fun signal_connect(signal_name: String, to_call: GtkCallable, user_data: nullable Object)

gtk :: GtkWidget :: signal_connect

intern fun sys: Sys

core :: Object :: sys

Return the global sys object, the only instance of the Sys class.
fun title=(title: String)

gtk :: GtkWindow :: title=

fun titlebar=(widget: GtkWidget)

gtk :: GtkWindow :: titlebar=

abstract fun to_jvalue(env: JniEnv): JValue

core :: Object :: to_jvalue

fun to_s: String

core :: Object :: to_s

User readable representation of self.
fun valign=(value: GtkAlign)

gtk :: GtkWidget :: valign=

Vertical alignement of this widget
fun visible: Bool

gtk :: GtkWidget :: visible

Get the visibility of the widget, check if it's parents are visible too
fun visible=(visible: Bool)

gtk :: GtkWidget :: visible=

Set the visibility of the widget
fun visible_self: Bool

gtk :: GtkWidget :: visible_self

Get the visibility of the widget only
package_diagram gtk::GtkWindow GtkWindow gtk::GtkBin GtkBin gtk::GtkWindow->gtk::GtkBin gtk::GtkContainer GtkContainer gtk::GtkBin->gtk::GtkContainer ...gtk::GtkContainer ... ...gtk::GtkContainer->gtk::GtkContainer gtk::GtkDialog GtkDialog gtk::GtkDialog->gtk::GtkWindow gtk::GtkAssistant GtkAssistant gtk::GtkAssistant->gtk::GtkWindow gtk::GtkAboutDialog GtkAboutDialog gtk::GtkAboutDialog->gtk::GtkDialog gtk::GtkAppChooserDialog GtkAppChooserDialog gtk::GtkAppChooserDialog->gtk::GtkDialog gtk::GtkColorChooserDialog GtkColorChooserDialog gtk::GtkColorChooserDialog->gtk::GtkDialog gtk::GtkFileChooserDialog GtkFileChooserDialog gtk::GtkFileChooserDialog->gtk::GtkDialog gtk::GtkFontChooserDialog GtkFontChooserDialog gtk::GtkFontChooserDialog->gtk::GtkDialog gtk::GtkMessageDialog GtkMessageDialog gtk::GtkMessageDialog->gtk::GtkDialog gtk::GtkRecentChooserDialog GtkRecentChooserDialog gtk::GtkRecentChooserDialog->gtk::GtkDialog gtk::GtkAboutDialog... ... gtk::GtkAboutDialog...->gtk::GtkAboutDialog gtk::GtkAppChooserDialog... ... gtk::GtkAppChooserDialog...->gtk::GtkAppChooserDialog gtk::GtkColorChooserDialog... ... gtk::GtkColorChooserDialog...->gtk::GtkColorChooserDialog gtk::GtkFileChooserDialog... ... gtk::GtkFileChooserDialog...->gtk::GtkFileChooserDialog gtk::GtkFontChooserDialog... ... gtk::GtkFontChooserDialog...->gtk::GtkFontChooserDialog gtk::GtkMessageDialog... ... gtk::GtkMessageDialog...->gtk::GtkMessageDialog gtk::GtkRecentChooserDialog... ... gtk::GtkRecentChooserDialog...->gtk::GtkRecentChooserDialog

Ancestors

extern class GtkContainer

gtk :: GtkContainer

Base class for widgets which contain other widgets
extern class GtkWidget

gtk :: GtkWidget

Base class for all widgets
interface Object

core :: Object

The root of the class hierarchy.
extern class Pointer

core :: Pointer

Pointer classes are used to manipulate extern C structures.

Parents

extern class GtkBin

gtk :: GtkBin

A container with just one child

Children

extern class GtkAssistant

gtk :: GtkAssistant

A widget used to guide users through multi-step operations
extern class GtkDialog

gtk :: GtkDialog

Create popup windows

Descendants

extern class GtkAboutDialog

gtk :: GtkAboutDialog

Display information about an application
extern class GtkAppChooserDialog

gtk :: GtkAppChooserDialog

An application chooser dialog
extern class GtkColorChooserDialog

gtk :: GtkColorChooserDialog

A dialog for choosing colors
extern class GtkFileChooserDialog

gtk :: GtkFileChooserDialog

A file chooser dialog, suitable for "File/Open" or "File/Save" commands
extern class GtkFontChooserDialog

gtk :: GtkFontChooserDialog

A dialog for selecting fonts
extern class GtkMessageDialog

gtk :: GtkMessageDialog

A convenient message window
extern class GtkRecentChooserDialog

gtk :: GtkRecentChooserDialog

Displays recently used files in a dialog

Class definitions

gtk $ GtkWindow
# Toplevel which can contain other widgets
# See: https://developer.gnome.org/gtk3/stable/GtkWindow.html
extern class GtkWindow `{GtkWindow *`}
	super GtkBin

	new (typ: GtkWindowType) `{
		return (GtkWindow *)gtk_window_new(typ);
	`}

	# Connect the "destroy" signal to `quit_gtk`
	fun connect_destroy_signal_to_quit `{
		g_signal_connect(self, "destroy", G_CALLBACK(gtk_main_quit), NULL);
	`}

	fun title=(title: String) import String.to_cstring `{
		gtk_window_set_title(self, String_to_cstring(title));
	`}

	# The "destroy" signal is emitted when a widget is destroyed, either by explicitly calling gtk_widget_destroy() or when the widget is unparented. Top-level GtkWindows are also destroyed when the Close window control button is clicked.
	fun on_close(to_call: GtkCallable, user_data: nullable Object)
	do
		signal_connect("destroy", to_call, user_data)
	end

	# Resize the window as if the user had done so
	fun resize(width, height: Int) `{
		return gtk_window_resize(self, width, height);
	`}

	fun resizable: Bool `{
		return gtk_window_get_resizable(self);
	`}

	fun resizable=(is_resizable: Bool) `{
		return gtk_window_set_resizable(self, is_resizable);
	`}

	# Activates the current focused widget within the window.
	# returns TRUE if a widget got activated.
	fun activate_focus: Bool `{
		return gtk_window_activate_focus(self);
	`}

	# Sets a window modal or non-modal. Modal windows prevent interaction with other windows in the same application.
	fun modal=(is_modal: Bool) `{
		gtk_window_set_modal(self, is_modal);
	`}

	# Windows can't actually be 0x0 in size, they must be at least 1x1
	# but passing 0 for width and height is OK, resulting in a 1x1 default size.
	# params width in pixels, or -1 to unset the default width
	# params height in pixels, or -1 to unset the default height
	fun default_size(width: Int, height: Int) `{
		gtk_window_set_default_size(self, width, height);
	`}

	# Activates the default widget for the window
	# unless the current focused widget has been configured to receive the default action (see gtk_widget_set_receives_default()), in which case the focused widget is activated.
	fun activate_default: Bool `{
		return gtk_window_activate_default(self);
	`}

	fun gravity: GdkGravity `{
		return gtk_window_get_gravity(self);
	`}

	fun gravity=(window_grav: GdkGravity) `{
		gtk_window_set_gravity(self, window_grav);
	`}

#	fun position: GtkWindowPosition `{
#		return gtk_window_get_position(self);
#	`}
#
#	fun position=(window_pos: GtkWindowPosition) `{
#		gtk_window_set_position(self, window_pos);
#	`}

	fun active: Bool `{
		return gtk_window_is_active(self);
	`}

	# Returns whether the input focus is within this GtkWindow. For real toplevel windows, this is identical to gtk_window_is_active(), but for embedded windows, like GtkPlug, the results will differ.
	fun has_toplevel_focus: Bool `{
		return gtk_window_has_toplevel_focus(self);
	`}

	fun get_focus: GtkWidget `{
		return gtk_window_get_focus(self);
	`}

	fun set_focus(widget: GtkWidget) `{
		return gtk_window_set_focus(self, widget);
	`}

	fun get_default_widget: GtkWidget `{
		return gtk_window_get_default_widget(self);
	`}

	fun set_default_widget(widget: GtkWidget) `{
		return gtk_window_set_default(self, widget);
	`}

	fun maximize `{
		return gtk_window_maximize(self);
	`}

	fun unmaximize `{
		return gtk_window_unmaximize(self);
	`}

	fun fullscreen `{
		return gtk_window_fullscreen(self);
	`}

	fun unfullscreen `{
		return gtk_window_unfullscreen(self);
	`}

	fun keep_above=(setting: Bool) `{
		gtk_window_set_keep_above(self, setting);
	`}

	fun keep_below=(setting: Bool) `{
		gtk_window_set_keep_below(self, setting);
	`}

	# Try to convince the window manage to decorate or not this window
	fun decorated=(setting: Bool) `{ gtk_window_set_decorated(self, setting); `}
end
lib/gtk/v3_4/gtk_core.nit:194,1--323,3

gtk :: v3_10 $ GtkWindow
redef class GtkWindow
	fun titlebar=(widget: GtkWidget) `{ gtk_window_set_titlebar(self, widget); `}
end
lib/gtk/v3_10.nit:20,1--22,3