Re: using cairo surfaces
- From: Ivan Baldo <ibaldo adinet com uy>
- To: Tommi Sakari Uimonen <tuimonen cc hut fi>
- Cc: gtk-app-devel-list gnome org
- Subject: Re: using cairo surfaces
- Date: Tue, 17 Oct 2006 18:52:45 -0200
If you have a cairo_t obtained from your expose_event callback and you
call it "cr", then on the child widgets you can create a surface with
cairo_surface_create_similar( cairo_get_target(cr), CAIRO_CONTENT_COLOR,
theWidthOfYourChild, theHeightOfYourChild);.
That surface will have the same format and properties of the surface
used in the expose event widget so it gives you the best performance.
Then you can create a cairo_t for that surface with: cairo_t *child_cr =
cairo_create( the_cairo_surface_t_you_obtained_from_create_similar);.
In that child_cr you can draw everything your child needs to draw; you
can cache it too so it can survive multiple expose events without
problems and without needing to draw anything.
When you need to draw that child in your expose event, then you just
need to do a cairo_rectangle() for the area you want to draw it on, then
call cairo_set_source_surface(child_cr, startPosH, startPosV) and then
cairo_fill() it :-).
IMPORTANT PERFORMANCE TIP: Carl Worth saw me crying about the bad
performance of my application and told me to use absolute values for
startPosH and startPosV (that is, instead of using say 54.35 use 54.00),
you can do that if it is not noticeable to the human eye in your case
(it depends on transformation matrices and scales you use, etc., just
try it out and see). Try it, because it can use some very fast paths for
drawing that in my application accelerated it a lot and it was really as
simple as that: just using absolute values for positioning the surface.
Well, I hope I had explained it correctly but if you don't understand
don't hesitate to ask for another try at explaining it, maybe a native
English speaker can write it better than I.
Goodbye.
P.s.: I encourage you to join the Cairo mailing list, maybe you get
faster and better answers relating to Cairo there.
El 02/10/06 08:58, Tommi Sakari Uimonen escribiÃ:
Hello. I'm trying to create a custom container widget that holds the child
widgets in a hbox (or scrollarea, after I learn how to use it). The child
widgets are using cairo for the drawing, and so is the container widget.
I want to optimize the container drawing since the child widgets don't always
need complete redrawing.
The child drawing is currently done to the container's cairo surface, which is
passed to each child widget, and childs draw to this surface. Reference to this
surface is stored and I'm using a private variable in the container widget that
keeps track of whether the childs need full redraw or can I use the stored
surface to do quick redraw without the need to call the childs' drawing
functions.
Now, I want the child widgets to have their own surfaces and each child should
handle the "smart drawing". So the child widget decides whether it uses the
previously rendered surface or redraws some parts. The container then just uses
set_source_surface to draw the child at desired position.
What kind of surface I should create in the child widgets and how do I copy it
to the container surface?
I've tried creating image surface, but I guess I was doing something wrong,
because nothing was drawn, or I got segfault. So I still have not found the
right way of doing it. The documentation is lacking examples, so I have
proceeded in "trial and error"-basis, and now I'm kind of stuck.
Tommi
_______________________________________________
gtk-app-devel-list mailing list
gtk-app-devel-list gnome org
http://mail.gnome.org/mailman/listinfo/gtk-app-devel-list
--
Ivan Baldo - ibaldo adinet com uy - http://ibaldo.codigolibre.net/
ICQ 10215364 - Phone/FAX (598) (2) 613 3223.
Caldas 1781, Malvin, Montevideo, Uruguay, South America.
We believe that we are free, but in reality we are not! Are we?
Alternatives: ibaldo codigolibre net - http://go.to/ibaldo
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]