Re: performance of goocanvas
- From: Damon Chaplin <damonachaplin gmail com>
- To: dmg uvic ca
- Cc: goocanvas-list <goocanvas-list gnome org>
- Subject: Re: performance of goocanvas
- Date: Tue, 19 Nov 2013 16:02:32 +0000
On Tue, 2013-11-19 at 21:38 +0900, D M German wrote:
Dear Damon,
first of all, thank you for helping me with porting xournal to
goocanvas. The work is almost complete. we only have to complete few
features, but it is now usable.
https://github.com/dmgerman/xournal/tree/gtk3
Today I compiled xournal for windows and tried in a relatively slow
tablet (lenovo thinkpad 2).
Unfortunately the performance of xournal using goocanvas is visibly
slower than libgnomecanvas. For instance:
1. When drawing we draw a line between the two last sampled
points. Goocanvas takes enough time to affect the responsiveness of the
drawing. I have fixed this problem by drawing directly to the canvas
using cairo, and once the pen is lifted, I draw the polygon using
goocanvas. So far this seems to be adequate.
2. Scrolling. This is where the performance is really affected. A page
full of text might have literally thousands of line segments that need
to be scrolled. Also, we currently support a mode in which the user can
have in a huge vertical canvas all the pages of a document (a huge
column with one page per row). The performance seems to be affected by
whether we use one page at a time, or all pages in the canvas.
Do you have any suggestions to improve performance?
Try to place items in groups, e.g. each page in a group. Then the entire
page can be skipped when not needed. It shouldn't matter how many pages
there are then.
Setting "antialias" to CAIRO_ANTIALIAS_NONE for the polylines may help.
Is the main problem with GooCanvasPolyline items? Maybe try to minimize
the number of line segments if possible.
Do you have a demo file that shows the problems?
Damon
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]