Difference between revisions of "Canvas SVG"

From FlightGear wiki
Jump to: navigation, search
(Background)
(Ideas)
Line 12: Line 12:
 
== Ideas ==
 
== Ideas ==
 
* run parsexml in a Nasal worker thread (problematic: while parsing/loading can happen asynchronously, the parser needs a handle to the canvas group to draw into, so need to synchronize access to that) <ref>https://forum.flightgear.org/viewtopic.php?f=4&t=34571&p=368880#p368707</ref>
 
* run parsexml in a Nasal worker thread (problematic: while parsing/loading can happen asynchronously, the parser needs a handle to the canvas group to draw into, so need to synchronize access to that) <ref>https://forum.flightgear.org/viewtopic.php?f=4&t=34571&p=368880#p368707</ref>
 +
* Stuart suggested to port svg.nas to C++
  
  

Revision as of 10:11, 31 May 2020

This article is a stub. You can help the wiki by expanding it.

Background

Some lower end RPi/Intel based computers are taking ~15 seconds to show the FG1000 device.

So there's currently a discussion taking place to optimize/port or re-implement Canvas SVG handling - could some more people please report here how long initialization of the FG1000 is taking for them ? Ideally, by using just the debug menu and checking how much time it takes for the PDF to show up ?

With some new MFDs making heavy use of SVG files, our way of using a custom scripted parser implemented in Nasal (svg.nas) is adding up considerably. i.e. performance is severely affected when processing such files.

On some platforms, just the initialization of the FG1000 is taking ~15 seconds - profiling shows most of the time is spent in ~1500 context switches between Nasal and C++ respectively.

Ideas

  • run parsexml in a Nasal worker thread (problematic: while parsing/loading can happen asynchronously, the parser needs a handle to the canvas group to draw into, so need to synchronize access to that) [1]
  • Stuart suggested to port svg.nas to C++


Native SVG handling via Canvas Image and the OSG SVG plugin (via librsvg)

References

References