[librsvg/rustify-rsvg-convert: 3/4] rsvg-convert: move cairo context creation within Surface
- From: Paolo Borelli <pborelli src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [librsvg/rustify-rsvg-convert: 3/4] rsvg-convert: move cairo context creation within Surface
- Date: Wed, 13 Jan 2021 08:29:31 +0000 (UTC)
commit 122f5496e86bd451508d7cde7721e13fc610ec6b
Author: Paolo Borelli <pborelli gnome org>
Date: Sun Jan 10 11:05:14 2021 +0100
rsvg-convert: move cairo context creation within Surface
src/bin/rsvg-convert/main.rs | 48 ++++++++++++++++++++++++--------------------
1 file changed, 26 insertions(+), 22 deletions(-)
---
diff --git a/src/bin/rsvg-convert/main.rs b/src/bin/rsvg-convert/main.rs
index 5ea8e58e..861ca21c 100644
--- a/src/bin/rsvg-convert/main.rs
+++ b/src/bin/rsvg-convert/main.rs
@@ -189,16 +189,28 @@ impl Surface {
pub fn render(
&self,
renderer: &CairoRenderer,
- cr: &cairo::Context,
+ scale: Scale,
+ background_color: Option<Color>,
id: Option<&str>,
) -> Result<(), RenderingError> {
- renderer
- .render_layer(cr, id, &self.bounds())
- .map(|_| {
- if !matches!(self, Self::Png(_, _)) {
- cr.show_page();
- }
- })
+ let cr = cairo::Context::new(self);
+
+ if let Some(Color::RGBA(rgba)) = background_color {
+ cr.set_source_rgba(
+ rgba.red_f32().into(),
+ rgba.green_f32().into(),
+ rgba.blue_f32().into(),
+ rgba.alpha_f32().into(),
+ );
+ }
+
+ cr.scale(scale.x, scale.y);
+
+ renderer.render_layer(&cr, id, &self.bounds()).map(|_| {
+ if !matches!(self, Self::Png(_, _)) {
+ cr.show_page();
+ }
+ })
}
pub fn finish(self) -> Result<(), cairo::IoError> {
@@ -419,21 +431,13 @@ impl Converter {
}
if let Some(ref surface) = target {
- let cr = cairo::Context::new(surface);
-
- if let Some(Color::RGBA(rgba)) = self.background_color {
- cr.set_source_rgba(
- rgba.red_f32().into(),
- rgba.green_f32().into(),
- rgba.blue_f32().into(),
- rgba.alpha_f32().into(),
- );
- }
-
- cr.scale(self.zoom.x, self.zoom.y);
-
surface
- .render(&renderer, &cr, self.export_id.as_deref())
+ .render(
+ &renderer,
+ self.zoom,
+ self.background_color,
+ self.export_id.as_deref(),
+ )
.unwrap_or_else(|e| exit!("Error rendering SVG {}: {}", input, e));
}
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]