[Fwd: Re: Newbie Q: What to use ...]

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




--- Begin Message ---
Jan-Marek Glogowski wrote:

Hi

From my first impression I think you can simply use a GtkDrawingArea and
GdkPixmap(s).

Look at GDK Docs -> Drawing Primitives, if you want to move from X to GDK.


Thank you, I have done that.

I think what confused me into thinking that GDK was not suitable, was those graphics contexts and color maps. Somehow, I got into thinking I could not easily define my own colors, but use some predefined sets. Meanwhile I have realized that is wrong :)

1) Stick with Xlib primitives for displaying ants ? OK, but I can't see
which kind of widget that will allow
me to use XLib drawing primitives on it, or how to somehow extract
an XWindow from a widget



GDK Docs -> X Window System Interaction


I will look once more. As far as I can see, it will generally give me handles for GDK components if I have some for X components. I wanted to go the other way - build a GTK UI, and then just "pick" out some underlying X components, and draw on those.

Anyway, it seems GDK is much more suitable, and I will avoid messing around at levels of my GUI where I have nothing to do. And easier too :)
'


As long as you don't have [moving] objects (like sprites), you want to
handle like GtkObjects (signals, ...), GnomeCanvas may be overkill.


As for the Gnome canvas: I think the GDK below is just fine for me.

3) Use GDK primitives ? But I need to be able to control the color of
the ants directly. Can I somehow
set the drawing foreground color in RGB directly ? Seems to me that
GDK was made for drawing
widgets, not much more.



Any drawing is done using GDK Graphics Contexts (GdkGC)

gdk_gc_set_foreground( GdkGC, GdkColor ), with

struct GdkColor {
 guint32 pixel;
 guint16 red;
 guint16 green;
 guint16 blue;
};

Simply create some GC with you required colors after widget realization,
if you just need some, and free them at unrealization.


Rrrrrrright.

Now my whole UI window will consist of
- a widget (Drawable) with the battlefield map, in whatever colors the ants request
- the usual bunch og GTK widgets


I have seen some general advice that one should use the same color map for all widgets in an UI. But I suppose that in this case it will be perfectly all right to install my special "ant" color map on only the battlefield widget ?

How do you want to handle window resize?


For the battlefield view: Verboten and meaningless anyway.
The game's logic does, however, resize the battlefield for each game in a tournament - I suppose if I carefully scrap and re-initialize the backing pixbuf in a configure event, everything should be handled automatically for me.'


The debugger view could be resizeable. The view is a magnified version of a small area of the battlefield - each pixel is boosted to 30x30 or so, and decorated with diagnostics information and widgets to control breakpoints, and display even more diagnostics info. That could be made resizeable. I suppose a resize could be translated into resizing the area magnified (luxury, elegance :) ), and that I can do that by just throwing out all data and rebuilding from scratch.

Do you want to support scrolling a larger image?


Not a must. Are there any viewport widgets that handle that automatically ? (Ok I really should look for myself).

Thanks a lot for the effort ! I solved part of it myself already, but confirmation is nice.

You can see the game at

www.myrekrig.dk

It's written by a Ph.D. student here some years ago, and as you can see (download, at software tab) the code is quite ugly. But the idea is brilliant !

The ant BayiMayi is my work.

Cheers,
Soren


--- End Message ---
_______________________________________________

gtk-list@xxxxxxxxx
http://mail.gnome.org/mailman/listinfo/gtk-list

[Index of Archives]     [Touch Screen Library]     [GIMP Users]     [Gnome]     [KDE]     [Yosemite News]     [Steve's Art]

  Powered by Linux