use crate::reader::driver::*;
use crate::structs::drawing::Point2DType;
use crate::structs::drawing::PositiveSize2DType;
use crate::writer::driver::*;
use crate::StringValue;
use quick_xml::events::{BytesStart, Event};
use quick_xml::Reader;
use quick_xml::Writer;
use std::io::Cursor;
#[derive(Clone, Default, Debug)]
pub struct Transform2D {
offset: Point2DType,
extents: PositiveSize2DType,
child_offset: Option<Box<Point2DType>>,
child_extents: Option<Box<PositiveSize2DType>>,
rot: StringValue,
flip_v: StringValue,
flip_h: StringValue,
}
impl Transform2D {
#[inline]
pub fn get_offset(&self) -> &Point2DType {
&self.offset
}
#[inline]
pub fn get_offset_mut(&mut self) -> &mut Point2DType {
&mut self.offset
}
#[inline]
pub fn set_offset(&mut self, value: Point2DType) {
self.offset = value;
}
#[inline]
pub fn get_extents(&self) -> &PositiveSize2DType {
&self.extents
}
#[inline]
pub fn get_extents_mut(&mut self) -> &mut PositiveSize2DType {
&mut self.extents
}
#[inline]
pub fn set_extents(&mut self, value: PositiveSize2DType) {
self.extents = value;
}
#[inline]
pub fn get_child_offset(&self) -> Option<&Point2DType> {
self.child_offset.as_deref()
}
#[inline]
pub fn get_child_offset_mut(&mut self) -> Option<&mut Point2DType> {
self.child_offset.as_deref_mut()
}
#[inline]
pub fn set_child_offset(&mut self, value: Point2DType) {
self.child_offset = Some(Box::new(value));
}
#[inline]
pub fn get_child_extents(&self) -> Option<&PositiveSize2DType> {
self.child_extents.as_deref()
}
#[inline]
pub fn get_child_extents_mut(&mut self) -> Option<&mut PositiveSize2DType> {
self.child_extents.as_deref_mut()
}
#[inline]
pub fn set_child_extents(&mut self, value: PositiveSize2DType) {
self.child_extents = Some(Box::new(value));
}
#[inline]
pub fn get_rot(&self) -> Option<&str> {
self.rot.get_value()
}
#[inline]
pub fn set_rot<S: Into<String>>(&mut self, value: S) {
self.rot.set_value(value);
}
#[inline]
pub fn get_flip_v(&self) -> Option<&str> {
self.flip_v.get_value()
}
#[inline]
pub fn set_flip_v<S: Into<String>>(&mut self, value: S) {
self.flip_v.set_value(value);
}
#[inline]
pub fn get_flip_h(&self) -> Option<&str> {
self.flip_h.get_value()
}
#[inline]
pub fn set_flip_h<S: Into<String>>(&mut self, value: S) {
self.flip_h.set_value(value);
}
pub(crate) fn set_attributes<R: std::io::BufRead>(
&mut self,
reader: &mut Reader<R>,
e: &BytesStart,
) {
if let Some(v) = get_attribute(e, b"rot") {
self.set_rot(v);
}
if let Some(v) = get_attribute(e, b"flipH") {
self.set_flip_h(v);
}
if let Some(v) = get_attribute(e, b"flipV") {
self.set_flip_v(v);
}
xml_read_loop!(
reader,
Event::Empty(ref e) => {
match e.name().into_inner() {
b"a:off" => {
self.offset.set_attributes(reader, e, true);
}
b"a:ext" => {
self.extents.set_attributes(reader, e, true);
}
b"a:chOff" => {
let mut obj = Point2DType::default();
obj.set_attributes(reader, e, true);
self.set_child_offset(obj);
}
b"a:chExt" => {
let mut obj = PositiveSize2DType::default();
obj.set_attributes(reader, e, true);
self.set_child_extents(obj);
}
_ => (),
}
},
Event::Start(ref e) => {
match e.name().into_inner() {
b"a:off" => {
self.offset.set_attributes(reader, e, false);
}
b"a:ext" => {
self.extents.set_attributes(reader, e, false);
}
b"a:chOff" => {
let mut obj = Point2DType::default();
obj.set_attributes(reader, e, false);
self.set_child_offset(obj);
}
b"a:chExt" => {
let mut obj = PositiveSize2DType::default();
obj.set_attributes(reader, e, false);
self.set_child_extents(obj);
}
_ => (),
}
},
Event::End(ref e) => {
if e.name().into_inner() == b"a:xfrm" {
return;
}
},
Event::Eof => panic!("Error: Could not find {} end element", "a:xfrm")
);
}
pub(crate) fn write_to(&self, writer: &mut Writer<Cursor<Vec<u8>>>) {
let mut attributes: Vec<(&str, &str)> = Vec::new();
if let Some(v) = self.rot.get_value() {
attributes.push(("rot", v))
}
if let Some(v) = self.flip_h.get_value() {
attributes.push(("flipH", v))
}
if let Some(v) = self.flip_v.get_value() {
attributes.push(("flipV", v))
}
write_start_tag(writer, "a:xfrm", attributes, false);
self.offset.write_to_off(writer);
self.extents.write_to_ext(writer);
match &self.child_offset {
Some(v) => {
v.write_to_ch_off(writer);
}
None => {}
}
match &self.child_extents {
Some(v) => {
v.write_to_ch_ext(writer);
}
None => {}
}
write_end_tag(writer, "a:xfrm");
}
}