| /******************************************************************************* | 
 |  * You may amend and distribute as you like, but don't remove this header! | 
 |  * | 
 |  * EPPlus provides server-side generation of Excel 2007/2010 spreadsheets. | 
 |  * See http://www.codeplex.com/EPPlus for details. | 
 |  * | 
 |  * Copyright (C) 2011  Jan Källman | 
 |  * | 
 |  * This library is free software; you can redistribute it and/or | 
 |  * modify it under the terms of the GNU Lesser General Public | 
 |  * License as published by the Free Software Foundation; either | 
 |  * version 2.1 of the License, or (at your option) any later version. | 
 |  | 
 |  * This library is distributed in the hope that it will be useful, | 
 |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
 |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.   | 
 |  * See the GNU Lesser General Public License for more details. | 
 |  * | 
 |  * The GNU Lesser General Public License can be viewed at http://www.opensource.org/licenses/lgpl-license.php | 
 |  * If you unfamiliar with this license or have questions about it, here is an http://www.gnu.org/licenses/gpl-faq.html | 
 |  * | 
 |  * All code and executables are provided "as is" with no warranty either express or implied.  | 
 |  * The author accepts no liability for any damage or loss of business that this product may cause. | 
 |  * | 
 |  * Code change notes: | 
 |  *  | 
 |  * Author							Change						Date | 
 |  * ****************************************************************************** | 
 |  * Jan Källman		Initial Release		        2010-06-01 | 
 |  * Jan Källman		License changed GPL-->LGPL 2011-12-16 | 
 |  *******************************************************************************/ | 
 | using System; | 
 | using System.Collections.Generic; | 
 | using System.Text; | 
 | using System.Xml; | 
 | using System.Collections; | 
 | using System.Globalization; | 
 | using OfficeOpenXml.Utils; | 
 |  | 
 | namespace OfficeOpenXml.Drawing.Vml | 
 | { | 
 |     public class ExcelVmlDrawingPictureCollection : ExcelVmlDrawingBaseCollection, IEnumerable | 
 |     { | 
 |         internal List<ExcelVmlDrawingPicture> _images; | 
 |         ExcelPackage _pck; | 
 |         ExcelWorksheet _ws; | 
 |         internal ExcelVmlDrawingPictureCollection(ExcelPackage pck, ExcelWorksheet ws, Uri uri) : | 
 |             base(pck, ws, uri) | 
 |         {             | 
 |             _pck = pck; | 
 |             _ws = ws; | 
 |             if (uri == null) | 
 |             { | 
 |                 VmlDrawingXml.LoadXml(CreateVmlDrawings()); | 
 |                 _images = new List<ExcelVmlDrawingPicture>(); | 
 |             } | 
 |             else | 
 |             { | 
 |                 AddDrawingsFromXml(); | 
 |             } | 
 |         } | 
 |  | 
 |         private void AddDrawingsFromXml() | 
 |         { | 
 |             var nodes = VmlDrawingXml.SelectNodes("//v:shape", NameSpaceManager); | 
 |             _images = new List<ExcelVmlDrawingPicture>(); | 
 |             foreach (XmlNode node in nodes) | 
 |             { | 
 |                 var img = new ExcelVmlDrawingPicture(node, NameSpaceManager, _ws); | 
 |                 var rel = Part.GetRelationship(img.RelId); | 
 |                 img.ImageUri = UriHelper.ResolvePartUri(rel.SourceUri, rel.TargetUri); | 
 |                 _images.Add(img); | 
 |             } | 
 |         } | 
 |  | 
 |         private string CreateVmlDrawings() | 
 |         { | 
 |             string vml=string.Format("<xml xmlns:v=\"{0}\" xmlns:o=\"{1}\" xmlns:x=\"{2}\">",  | 
 |                 ExcelPackage.schemaMicrosoftVml,  | 
 |                 ExcelPackage.schemaMicrosoftOffice,  | 
 |                 ExcelPackage.schemaMicrosoftExcel); | 
 |              | 
 |              vml+="<o:shapelayout v:ext=\"edit\">"; | 
 |              vml+="<o:idmap v:ext=\"edit\" data=\"1\"/>"; | 
 |              vml+="</o:shapelayout>"; | 
 |  | 
 |              vml+="<v:shapetype id=\"_x0000_t202\" coordsize=\"21600,21600\" o:spt=\"202\" path=\"m,l,21600r21600,l21600,xe\">"; | 
 |              vml+="<v:stroke joinstyle=\"miter\" />"; | 
 |              vml+="<v:path gradientshapeok=\"t\" o:connecttype=\"rect\" />"; | 
 |              vml+="</v:shapetype>"; | 
 |              vml+= "</xml>"; | 
 |  | 
 |             return vml; | 
 |         } | 
 |         internal ExcelVmlDrawingPicture Add(string id, Uri uri, string name, double width, double height) | 
 |         { | 
 |             XmlNode node = AddImage(id, uri, name, width, height); | 
 |             var draw = new ExcelVmlDrawingPicture(node, NameSpaceManager, _ws); | 
 |             draw.ImageUri = uri; | 
 |             _images.Add(draw); | 
 |             return draw; | 
 |         } | 
 |         private XmlNode AddImage(string id, Uri targeUri, string Name, double width, double height) | 
 |         { | 
 |             var node = VmlDrawingXml.CreateElement("v", "shape", ExcelPackage.schemaMicrosoftVml); | 
 |             VmlDrawingXml.DocumentElement.AppendChild(node); | 
 |             node.SetAttribute("id", id); | 
 |             node.SetAttribute("o:type", "#_x0000_t75"); | 
 |             node.SetAttribute("style", string.Format("position:absolute;margin-left:0;margin-top:0;width:{0}pt;height:{1}pt;z-index:1", width.ToString(CultureInfo.InvariantCulture), height.ToString(CultureInfo.InvariantCulture))); | 
 |             //node.SetAttribute("fillcolor", "#ffffe1"); | 
 |             //node.SetAttribute("insetmode", ExcelPackage.schemaMicrosoftOffice, "auto"); | 
 |  | 
 |             node.InnerXml = string.Format("<v:imagedata o:relid=\"\" o:title=\"{0}\"/><o:lock v:ext=\"edit\" rotation=\"t\"/>",  Name); | 
 |             return node; | 
 |         } | 
 |         /// <summary> | 
 |         /// Indexer | 
 |         /// </summary> | 
 |         /// <param name="Index">Index</param> | 
 |         /// <returns>The VML Drawing Picture object</returns> | 
 |         public ExcelVmlDrawingPicture this[int Index] | 
 |         { | 
 |             get | 
 |             { | 
 |                 return _images[Index] as ExcelVmlDrawingPicture; | 
 |             } | 
 |         } | 
 |         public int Count | 
 |         { | 
 |             get | 
 |             { | 
 |                 return _images.Count; | 
 |             } | 
 |         } | 
 |  | 
 |         int _nextID = 0; | 
 |         /// <summary> | 
 |         /// returns the next drawing id. | 
 |         /// </summary> | 
 |         /// <returns></returns> | 
 |         internal string GetNewId() | 
 |         { | 
 |             if (_nextID == 0) | 
 |             { | 
 |                 foreach (ExcelVmlDrawingComment draw in this) | 
 |                 { | 
 |                     if (draw.Id.Length > 3 && draw.Id.StartsWith("vml")) | 
 |                     { | 
 |                         int id; | 
 |                         if (int.TryParse(draw.Id.Substring(3, draw.Id.Length - 3), out id)) | 
 |                         { | 
 |                             if (id > _nextID) | 
 |                             { | 
 |                                 _nextID = id; | 
 |                             } | 
 |                         } | 
 |                     } | 
 |                 } | 
 |             } | 
 |             _nextID++; | 
 |             return "vml" + _nextID.ToString(); | 
 |         } | 
 |         #region IEnumerable Members | 
 |  | 
 |         IEnumerator IEnumerable.GetEnumerator()  | 
 |         { | 
 |             return _images.GetEnumerator(); | 
 |         } | 
 |  | 
 |         #endregion | 
 |     } | 
 | } |