SYNOPSIS

MFrame* mframe (MPlist * plist)

DESCRIPTION

Create a new frame. The mframe() function creates a new frame with parameters listed in plist which may be NULL.

The recognized keys in plist are window system dependent.

The following key is always recognized.

  • Mdevice, the value must be one of Mx, Mgd, and Mnil.

If the value is Mx, the frame is for X Window System. The argument MDrawWindow specified together with the frame must be of type Window. The frame is both readable and writable, thus all GUI functions can be used.

If the value is Mgd, the frame is for an image object of GD library. The argument MDrawWindow specified together with the frame must be of type gdImagePtr. The frame is writable only, thus functions minput_XXX can't be used for the frame.

If the value is Mnil, the frame is for a null device. The frame is not writable nor readable, thus functions mdraw_XXX that require the argument MDrawWindow and functions minput_XXX can't be used for the frame.

  • Mface, the value must be a pointer to MFace.

The value is used as the default face of the frame.

In addition, if the value of the key Mdevice is Mx, the following keys are recognized. They are to specify the root window and the depth of drawables that can be used with the frame.

  • Mdrawable, the value type must be Drawable.

A parameter of key Mdisplay must also be specified. The created frame can be used for drawables whose root window and depth are the same as those of the specified drawable on the specified display.

When this parameter is specified, the parameter of key Mscreen is ignored.

  • Mwidget, the value type must be Widget.

The created frame can be used for drawables whose root window and depth are the same as those of the specified widget.

If a parameter of key Mface is not specified, the default face is created from the resources of the widget.

When this parameter is specified, the parameters of key Mdisplay, Mscreen, Mdrawable, Mdepth are ignored.

  • Mdepth, the value type must be unsigned.

The created frame can be used for drawables of the specified depth.

  • Mscreen, the value type must be (Screen *).

The created frame can be used for drawables whose root window is the same as the root window of the specified screen, and depth is the same at the default depth of the screen.

When this parameter is specified, parameter of key Mdisplay is ignored.

  • Mdisplay, the value type must be (Display *).

The created frame can be used for drawables whose root window is the same as the root window for the default screen of the display, and depth is the same as the default depth of the screen.

  • Mcolormap, the value type must be (Colormap).

The created frame uses the specified colormap.

  • Mfont, the value must be Mx, Mfreetype, or Mxft.

The created frame uses the specified font backend. The value Mx instructs to use X core fonts, Mfreetype to use local fonts supported by FreeType fonts, and Mxft to use local fonts via Xft library. You can specify this parameter more than once with different values if you want to use multiple font backends. This is ignored if the specified font backend is not supported on the device.

When this parameter is not specified, all font backend supported on the device are used.

RETURN VALUE

If the operation was successful, mframe() returns a pointer to a newly created frame. Otherwise, it returns NULL.

COPYRIGHT

Copyright (C) 2001 Information-technology Promotion Agency (IPA)

Copyright (C) 2001-2011 National Institute of Advanced Industrial Science and Technology (AIST)

Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License <http://www.gnu.org/licenses/fdl.html>.