//------------------------------------------------------------------- void flush() { if (_poly != null && _poly.Points.Count > 0) { _parent.draw(_poly, _id); } _poly = new Polyline(); _repr = ""; }
//------------------------------------------------------------------- public override bool ReadFile(string path) { //CamBam.ThisApplication.MsgBox("SVG: " + path); XmlDocument xml = new XmlDocument(); xml.Load(path); trace("SVG loaded: " + path); Graphics graphics = new Graphics(_output); graphics.draw(xml); return(true); }
static void OpenSVG_Click(object sender, EventArgs e) { string path = string.Empty; string title = string.Format("SVG Loader version {0}", _version); OpenFileDialog dlg = new OpenFileDialog(); dlg.Title = title; dlg.Filter = "SVG files (*.svg)|*.svg|All files (*.*)|*.*"; if (dlg.ShowDialog() != DialogResult.OK) { return; } path = dlg.FileName; OutputCAD output = new OutputCAD(Plugin._ui); XmlDocument xml = new XmlDocument(); xml.Load(path); Graphics graphics = new Graphics(output); graphics.draw(xml); }
public static void Main(string[] args) { #if false double[] m; double[] x0 = new double[2] { 0, 0 }; double[] x1 = new double[2] { -1, 0 }; double[] x2 = new double[2] { +1, 0 }; double[] x3 = new double[2] { 0, -1 }; double[] x4 = new double[2] { 0, +1 }; double[] x5 = new double[2] { 10, 5 }; m = SVGLoader.Geometry.circle_center(x1, x2, 1); m = SVGLoader.Geometry.circle_center(x3, x4, 1); m = SVGLoader.Geometry.circle_center(x1, x4, 1); m = SVGLoader.Geometry.circle_center(x0, x5, 10, false); string str = "scale ( -.1) "; //string s_re = "scale"; ITransform tr = SVGLoader.Parser.transform(str); SVGLoader.Transform t1 = new SVGLoader.Transform(Math.PI); double[] p0 = new double[3] { 1, 2, 3 }; double[] p1 = t1.calc(p0); double[] p2 = t1.calc(1, 2, 3); SVGLoader.ITransform t2 = new SVGLoader.Translate(2, 2); t1.rotate(0); t1.scale(); t1.scale(-1, 1, 3); p1 = t2.calc(p0); Stack <ITransform> t3 = new Stack <ITransform> (); t3.Push(t2); t3.Push(t1); p1 = (double[])p0.Clone(); foreach (ITransform t in t3) { p1 = t.calc(p1); } MultiTransform t4 = new MultiTransform(t3); p1 = t4.calc(p0); Queue <ITransform> queue = new Queue <ITransform> (); queue.Enqueue(t1); MultiTransform t5 = new MultiTransform(queue); p1 = t5.calc(p0); #endif Stdout stdout = new Stdout(); SVGLoader.Graphics graphics = new SVGLoader.Graphics(stdout); //string path = "/home/jvater/c#-prj/data/test.svg"; //string path = "/home/jvater/prj/svg-loader/data/Steg.svg"; //string path = "/home/jvater/prj/svg-loader/data/test-00.svg"; string path = "/home/jvater/prj/svg-loader/data/forum-01/Acanthus.svg"; Console.WriteLine("Hello World!"); //CamBam.ThisApplication.MsgBox("SVG: " + path); XmlDocument xml = new XmlDocument(); xml.Load(path); XmlNodeList list = xml.GetElementsByTagName("defs"); //XmlElement y = xml.GetElementById ("vol"); XmlNode y = xml.SelectSingleNode("//*[@id='vol']"); foreach (XmlElement x in list) { stdout.trace(1, x.ToString()); } stdout.trace(0, "SVG loaded:" + path); graphics.draw(xml); }