forked from AuroraMiddleware/gtk
0cdc00ec0b
Wed Oct 25 14:17:43 2000 Owen Taylor <otaylor@redhat.com> * gtk/gtkwidget.[ch] (gtk_widget_is_focus): Add a function to determine if a window is the focus widget within its toplevel. * gtk/gtkcontainer.[ch]: Fix the return type of ::focus to be boolean. * gtk/gtkcontainer.c (gtk_container_real_focus): Move handling of the case where the container CAN_FOCUS to here instead of having it in each individual move-the-focus place. * gtk/gtkcontainer.c: Rewrite handling of left-right and up-down focusing to be geometric in a much more obvious sense. Arrowing around is still non-intuitive because it isn't perfect and because entries, etc, grab the arrow keys, but it at least usually will do what you expect now. * gtk/gtknotebook.[ch]: Many cleanups. Moved docs inline in this file. * gtk/gtknotebook.c: Change tabs to be a single item in the focus chain. Make movement of focus on tabs with arrow keys wrap around. * gtk/gtknotebook.c (gtk_notebook_find_child): Add CHECK_FIND_CHILD macro to give informative error messages instead of silent returns. * gtk/gtknotebook.c (gtk_notebook_init): Set the RECEIVES_DEFAULT flag since we handle GdkReturn on the tabs. * gtk/gtknotebook.c (gtk_notebook_expose_tabs): Invalidate windows rather than sending expose events directly. * gtk/gtknotebook.[ch] docs/Changes-2.0.txt: Move structure definition for GtkNotebookPage into .c file, since it is private. * gtk/testgtk.c (create_notebook): Add option for testing borderless notebook. * gtk/testgtk.c (page_switch): Removed egregious poking around in GTK+ internals. * docs/widget-system.txt: Remove references to GTK_REDRAW_PENDING. * gtk/gtkclist.[ch]: Remove key press handler, handle focusing properly through gtk_clist_focus. Make the title headers a single item in the tab-focus chain, and make left-right wrap around. * gtk/gtkwindow.c (gtk_window_focus): Add a custom focus method so that wrapping around works properly. * gtk/gtktreeview.c: Remove calls to gtk_container_set_focus_child() - that is handled for the widget now. |
||
---|---|---|
.. | ||
faq | ||
reference | ||
tutorial | ||
.cvsignore | ||
Changes-1.2.txt | ||
Changes-2.0.txt | ||
debugging.txt | ||
defsformat.txt | ||
developers.txt | ||
dnd_internals.txt | ||
generation.txt | ||
gtk-config.1.in | ||
gtk-config.txt | ||
gtkdocs_fix | ||
make-todo | ||
Makefile.am | ||
README.linux-fb | ||
refcounting.txt | ||
styles.txt | ||
text_widget.txt | ||
widget_system.txt |
About GtkFB: ------------ The linux-fb port of Gtk+, also known as GtkFB is an implementation of gdk (and therefor gtk) that runs on the linux framebuffer. It runs in a single process that doesn't need X. It should run most Gtk+ programs without any changes to the source. Build requirements: ------------------- To run GtkFB programs you will need glib, pango and gtk from cvs HEAD. Make sure you update these at the same time, since changes to glib and pango often forces changes in gtk+. Pango optionally depends on libfribidi, but for normal GtkFB usage that can be ignored. You also need freetype 2, I recommend that you use freetype 2.0.1 or later, as there was some problems with freetype-config in 2.0. Freetype can be found at ftp://ftp.freetype.org Hardware requirements: ---------------------- You need a graphics card with an availible framebuffer driver that can run in 8, 16, 24 or 32 bpp. I use the matroxfb driver, but i.e. vesafb should work too. You also need a supported mouse. Currently supported is ps2 mouse, ms serial mouse and fidmour touchscreen. Building and installing: ------------------------ First build and install glib and pango as usual, in that order. Then configure Gtk by running configure (or autogen.sh if running from cvs) with --with-gdktarget=linux-fb. Make sure that pango and gtk+ are installed in the same prefix, as gtk+ installs a new pango module that pango must be able to find. Then compile as ususal: make; make install This installs a new pango module that pango must be instructed to find. This is done by running something like: pango-querymodules > /your_prefix/etc/pango/pango.modules (look at this file and make sure it contains a row with fb-basic.so. Fonts: ------ Since GtkFB uses freetype 2 to render fonts it can render truetype and postscript type 1 antialiased fonts. At startup it scans these directories looking for any fonts: /usr/share/fonts/default/TrueType /usr/share/fonts/default/Type1 /usr/lib/X11/fonts/TrueType /usr/lib/X11/fonts/Type1 $(prefix)/share/fonts It also has a hardcoded font alias handling. This is important because most program refers to the standard fonts by the names "Sans", "Serif" and "Monotype". The default aliases in GtkFB maps these to the M$ truetype fonts: Arial, Times New Roman, and Courier New (you need to own a copy of Windows to use these) and the type1 fonts URW Gothic, URW Bookman and Courier. You will need to have at least Arial or URW Gothic installed, because the "Sans" font is used as a last case font. If you've done all this and fonts still doesn't work, make sure you've run pango-querymodules as described in the building and installing section. Running: -------- To run a program you should only need to start it, but there are some things that can cause problems, and some things that can be controlled by environment variables. Try testgtk distributed with gtk+ to test if things work. If you use a ps2 mouse, make sure that /dev/psaux is readable and writable. Make sure gpm is not running. If you don't specify anything GtkFB will start up in the current virtual console in the current resolution and bit-depth. This can be changed by specifying environment variables: GDK_VT: unset means open on the current VT. 0-9: open on the specified VT. Make sure you have read/write rights there. new: Allocate a new VT after the last currently used one. GDK_DISPLAY_MODE: Specifies the name of a mode in /etc/fb.modes that you want to use. GDK_DISPLAY_DEPTH: Specify the desired bit depth of the framebuffer. GDK_DISPLAY_WIDTH: Specify the desired width of the framebuffer. GDK_DISPLAY_HEIGHT: Specify the desired height of the framebuffer. GDK_DISPLAY: Specify the framebuffer device to use. Default is /dev/fb0 GDK_MOUSE_TYPE: Specify mouse type. Currently supported is: ps2 - PS/2 mouse ms - Microsoft serial mouse fidmour - touch screen Default is ps2. GDK_KEYBOARD_TYPE: Specify keyboard type. Currently suppored is xlate - normal tty mode keyboard. Quite limited, cannot detect key up/key down events. Doesn't handle ctrl/alt/shift for all keys. This is the default driver, but should not be used in "production" use. raw - read from the tty in RAW mode. Sets the keyboard in RAW mode and handles all the keycodes. This gives correct handling of modifiers and key up/down events. You must be root to use this. If you use this for development or debugging it is recommended to enable magic sysrq handling in the kernel. Then you can use ALT-SysRQ-r to turn the keyboard back to normal mode. Default is xlate. HACKING: -------- Pressing shift-F1 forces a repaint of the whole screen. To be written. - Alexander Larsson <alexl@redhat.com> 2000/12/06