1 | /*******************************************************************************
|
---|
2 | * You may amend and distribute as you like, but don't remove this header!
|
---|
3 | *
|
---|
4 | * EPPlus provides server-side generation of Excel 2007/2010 spreadsheets.
|
---|
5 | * See http://www.codeplex.com/EPPlus for details.
|
---|
6 | *
|
---|
7 | * Copyright (C) 2011 Jan Källman
|
---|
8 | *
|
---|
9 | * This library is free software; you can redistribute it and/or
|
---|
10 | * modify it under the terms of the GNU Lesser General Public
|
---|
11 | * License as published by the Free Software Foundation; either
|
---|
12 | * version 2.1 of the License, or (at your option) any later version.
|
---|
13 |
|
---|
14 | * This library is distributed in the hope that it will be useful,
|
---|
15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
---|
16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
---|
17 | * See the GNU Lesser General Public License for more details.
|
---|
18 | *
|
---|
19 | * The GNU Lesser General Public License can be viewed at http://www.opensource.org/licenses/lgpl-license.php
|
---|
20 | * If you unfamiliar with this license or have questions about it, here is an http://www.gnu.org/licenses/gpl-faq.html
|
---|
21 | *
|
---|
22 | * All code and executables are provided "as is" with no warranty either express or implied.
|
---|
23 | * The author accepts no liability for any damage or loss of business that this product may cause.
|
---|
24 | *
|
---|
25 | * Code change notes:
|
---|
26 | *
|
---|
27 | * Author Change Date
|
---|
28 | * ******************************************************************************
|
---|
29 | * Jan Källman Initial Release 2010-06-01
|
---|
30 | * Jan Källman License changed GPL-->LGPL 2011-12-16
|
---|
31 | *******************************************************************************/
|
---|
32 | using System;
|
---|
33 | using System.Collections;
|
---|
34 | using System.Collections.Generic;
|
---|
35 | using System.Globalization;
|
---|
36 | using System.Text;
|
---|
37 | using System.Xml;
|
---|
38 | using OfficeOpenXml.Drawing.Chart;
|
---|
39 | namespace OfficeOpenXml.Drawing
|
---|
40 | {
|
---|
41 | /// <summary>
|
---|
42 | /// Text anchoring
|
---|
43 | /// </summary>
|
---|
44 | public enum eTextAnchoringType
|
---|
45 | {
|
---|
46 | Bottom,
|
---|
47 | Center,
|
---|
48 | Distributed,
|
---|
49 | Justify,
|
---|
50 | Top
|
---|
51 | }
|
---|
52 | /// <summary>
|
---|
53 | /// Vertical text type
|
---|
54 | /// </summary>
|
---|
55 | public enum eTextVerticalType
|
---|
56 | {
|
---|
57 | EastAsianVertical,
|
---|
58 | Horizontal,
|
---|
59 | MongolianVertical,
|
---|
60 | Vertical,
|
---|
61 | Vertical270,
|
---|
62 | WordArtVertical,
|
---|
63 | WordArtVerticalRightToLeft
|
---|
64 |
|
---|
65 | }
|
---|
66 | /// <summary>
|
---|
67 | /// How the drawing will be resized.
|
---|
68 | /// </summary>
|
---|
69 | public enum eEditAs
|
---|
70 | {
|
---|
71 | /// <summary>
|
---|
72 | /// Specifies that the current start and end positions shall
|
---|
73 | /// be maintained with respect to the distances from the
|
---|
74 | /// absolute start point of the worksheet.
|
---|
75 | /// </summary>
|
---|
76 | Absolute,
|
---|
77 | /// <summary>
|
---|
78 | /// Specifies that the current drawing shall move with its
|
---|
79 | ///row and column (i.e. the object is anchored to the
|
---|
80 | /// actual from row and column), but that the size shall
|
---|
81 | ///remain absolute.
|
---|
82 | /// </summary>
|
---|
83 | OneCell,
|
---|
84 | /// <summary>
|
---|
85 | /// Specifies that the current drawing shall move and
|
---|
86 | /// resize to maintain its row and column anchors (i.e. the
|
---|
87 | /// object is anchored to the actual from and to row and column).
|
---|
88 | /// </summary>
|
---|
89 | TwoCell
|
---|
90 | }
|
---|
91 | /// <summary>
|
---|
92 | /// Base class for twoanchored drawings.
|
---|
93 | /// Drawings are Charts, shapes and Pictures.
|
---|
94 | /// </summary>
|
---|
95 | public class ExcelDrawing : XmlHelper, IDisposable
|
---|
96 | {
|
---|
97 | /// <summary>
|
---|
98 | /// Position of the a drawing.
|
---|
99 | /// </summary>
|
---|
100 | public class ExcelPosition : XmlHelper
|
---|
101 | {
|
---|
102 | XmlNode _node;
|
---|
103 | XmlNamespaceManager _ns;
|
---|
104 | internal ExcelPosition(XmlNamespaceManager ns, XmlNode node) :
|
---|
105 | base (ns,node)
|
---|
106 | {
|
---|
107 | _node = node;
|
---|
108 | _ns = ns;
|
---|
109 | }
|
---|
110 | const string colPath="xdr:col";
|
---|
111 | public int Column
|
---|
112 | {
|
---|
113 | get
|
---|
114 | {
|
---|
115 | return GetXmlNodeInt(colPath);
|
---|
116 | }
|
---|
117 | set
|
---|
118 | {
|
---|
119 | SetXmlNodeString(colPath, value.ToString());
|
---|
120 | }
|
---|
121 | }
|
---|
122 | const string rowPath="xdr:row";
|
---|
123 | public int Row
|
---|
124 | {
|
---|
125 | get
|
---|
126 | {
|
---|
127 | return GetXmlNodeInt(rowPath);
|
---|
128 | }
|
---|
129 | set
|
---|
130 | {
|
---|
131 | SetXmlNodeString(rowPath, value.ToString());
|
---|
132 | }
|
---|
133 | }
|
---|
134 | const string colOffPath = "xdr:colOff";
|
---|
135 | /// <summary>
|
---|
136 | /// Column Offset
|
---|
137 | ///
|
---|
138 | /// EMU units 1cm = 1/360000
|
---|
139 | /// 1US inch = 1/914400
|
---|
140 | /// 1pixel = 1/9525
|
---|
141 | /// </summary>
|
---|
142 | public int ColumnOff
|
---|
143 | {
|
---|
144 | get
|
---|
145 | {
|
---|
146 | return GetXmlNodeInt(colOffPath);
|
---|
147 | }
|
---|
148 | set
|
---|
149 | {
|
---|
150 | SetXmlNodeString(colOffPath, value.ToString());
|
---|
151 | }
|
---|
152 | }
|
---|
153 | const string rowOffPath = "xdr:rowOff";
|
---|
154 | /// <summary>
|
---|
155 | /// Row Offset
|
---|
156 | ///
|
---|
157 | /// EMU units 1cm = 1/360000
|
---|
158 | /// 1US inch = 1/914400
|
---|
159 | /// 1pixel = 1/9525
|
---|
160 | /// </summary>
|
---|
161 | public int RowOff
|
---|
162 | {
|
---|
163 | get
|
---|
164 | {
|
---|
165 | return GetXmlNodeInt(rowOffPath);
|
---|
166 | }
|
---|
167 | set
|
---|
168 | {
|
---|
169 | SetXmlNodeString(rowOffPath, value.ToString());
|
---|
170 | }
|
---|
171 | }
|
---|
172 | }
|
---|
173 | protected ExcelDrawings _drawings;
|
---|
174 | protected XmlNode _topNode;
|
---|
175 | string _nameXPath;
|
---|
176 | protected internal int _id;
|
---|
177 | const float STANDARD_DPI = 96;
|
---|
178 | public const int EMU_PER_PIXEL = 9525;
|
---|
179 |
|
---|
180 | internal ExcelDrawing(ExcelDrawings drawings, XmlNode node, string nameXPath) :
|
---|
181 | base(drawings.NameSpaceManager, node)
|
---|
182 | {
|
---|
183 | _drawings = drawings;
|
---|
184 | _topNode = node;
|
---|
185 | _id = drawings.Worksheet.Workbook._nextDrawingID++;
|
---|
186 | XmlNode posNode = node.SelectSingleNode("xdr:from", drawings.NameSpaceManager);
|
---|
187 | if (node != null)
|
---|
188 | {
|
---|
189 | From = new ExcelPosition(drawings.NameSpaceManager, posNode);
|
---|
190 | }
|
---|
191 | posNode = node.SelectSingleNode("xdr:to", drawings.NameSpaceManager);
|
---|
192 | if (node != null)
|
---|
193 | {
|
---|
194 | To = new ExcelPosition(drawings.NameSpaceManager, posNode);
|
---|
195 | }
|
---|
196 | else
|
---|
197 | {
|
---|
198 | To = null;
|
---|
199 | }
|
---|
200 | _nameXPath = nameXPath;
|
---|
201 | SchemaNodeOrder = new string[] { "from", "to", "graphicFrame", "sp", "clientData" };
|
---|
202 | }
|
---|
203 | /// <summary>
|
---|
204 | /// The name of the drawing object
|
---|
205 | /// </summary>
|
---|
206 | public string Name
|
---|
207 | {
|
---|
208 | get
|
---|
209 | {
|
---|
210 | try
|
---|
211 | {
|
---|
212 | if (_nameXPath == "") return "";
|
---|
213 | return GetXmlNodeString(_nameXPath);
|
---|
214 | }
|
---|
215 | catch
|
---|
216 | {
|
---|
217 | return "";
|
---|
218 | }
|
---|
219 | }
|
---|
220 | set
|
---|
221 | {
|
---|
222 | try
|
---|
223 | {
|
---|
224 | if (_nameXPath == "") throw new NotImplementedException();
|
---|
225 | SetXmlNodeString(_nameXPath, value);
|
---|
226 | }
|
---|
227 | catch
|
---|
228 | {
|
---|
229 | throw new NotImplementedException();
|
---|
230 | }
|
---|
231 | }
|
---|
232 | }
|
---|
233 | /// <summary>
|
---|
234 | /// How Excel resize drawings when the column width is changed within Excel.
|
---|
235 | /// The width of drawings are currently NOT resized in EPPLus when the column width changes
|
---|
236 | /// </summary>
|
---|
237 | public eEditAs EditAs
|
---|
238 | {
|
---|
239 | get
|
---|
240 | {
|
---|
241 | try
|
---|
242 | {
|
---|
243 | string s = GetXmlNodeString("@editAs");
|
---|
244 | if (s == "")
|
---|
245 | {
|
---|
246 | return eEditAs.TwoCell;
|
---|
247 | }
|
---|
248 | else
|
---|
249 | {
|
---|
250 | return (eEditAs)Enum.Parse(typeof(eEditAs), s,true);
|
---|
251 | }
|
---|
252 | }
|
---|
253 | catch
|
---|
254 | {
|
---|
255 | return eEditAs.TwoCell;
|
---|
256 | }
|
---|
257 | }
|
---|
258 | set
|
---|
259 | {
|
---|
260 | string s=value.ToString();
|
---|
261 | SetXmlNodeString("@editAs", s.Substring(0,1).ToLower(CultureInfo.InvariantCulture)+s.Substring(1,s.Length-1));
|
---|
262 | }
|
---|
263 | }
|
---|
264 | const string lockedPath="xdr:clientData/@fLocksWithSheet";
|
---|
265 | /// <summary>
|
---|
266 | /// Lock drawing
|
---|
267 | /// </summary>
|
---|
268 | public bool Locked
|
---|
269 | {
|
---|
270 | get
|
---|
271 | {
|
---|
272 | return GetXmlNodeBool(lockedPath, true);
|
---|
273 | }
|
---|
274 | set
|
---|
275 | {
|
---|
276 | SetXmlNodeBool(lockedPath, value);
|
---|
277 | }
|
---|
278 | }
|
---|
279 | const string printPath = "xdr:clientData/@fPrintsWithSheet";
|
---|
280 | /// <summary>
|
---|
281 | /// Print drawing with sheet
|
---|
282 | /// </summary>
|
---|
283 | public bool Print
|
---|
284 | {
|
---|
285 | get
|
---|
286 | {
|
---|
287 | return GetXmlNodeBool(printPath, true);
|
---|
288 | }
|
---|
289 | set
|
---|
290 | {
|
---|
291 | SetXmlNodeBool(printPath, value);
|
---|
292 | }
|
---|
293 | } /// <summary>
|
---|
294 | /// Top Left position
|
---|
295 | /// </summary>
|
---|
296 | public ExcelPosition From { get; set; }
|
---|
297 | /// <summary>
|
---|
298 | /// Bottom right position
|
---|
299 | /// </summary>
|
---|
300 | public ExcelPosition To
|
---|
301 | {
|
---|
302 | get;
|
---|
303 | set;
|
---|
304 | }
|
---|
305 | /// <summary>
|
---|
306 | /// Add new Drawing types here
|
---|
307 | /// </summary>
|
---|
308 | /// <param name="drawings">The drawing collection</param>
|
---|
309 | /// <param name="node">Xml top node</param>
|
---|
310 | /// <returns>The Drawing object</returns>
|
---|
311 | internal static ExcelDrawing GetDrawing(ExcelDrawings drawings, XmlNode node)
|
---|
312 | {
|
---|
313 | if (node.SelectSingleNode("xdr:sp", drawings.NameSpaceManager) != null)
|
---|
314 | {
|
---|
315 | return new ExcelShape(drawings, node);
|
---|
316 | }
|
---|
317 | else if (node.SelectSingleNode("xdr:pic", drawings.NameSpaceManager) != null)
|
---|
318 | {
|
---|
319 | return new ExcelPicture(drawings, node);
|
---|
320 | }
|
---|
321 | else if (node.SelectSingleNode("xdr:graphicFrame", drawings.NameSpaceManager) != null)
|
---|
322 | {
|
---|
323 | return ExcelChart.GetChart(drawings, node);
|
---|
324 | }
|
---|
325 | else
|
---|
326 | {
|
---|
327 | return new ExcelDrawing(drawings, node, "");
|
---|
328 | }
|
---|
329 | }
|
---|
330 | internal string Id
|
---|
331 | {
|
---|
332 | get { return _id.ToString(); }
|
---|
333 | }
|
---|
334 | internal static string GetTextAchoringText(eTextAnchoringType value)
|
---|
335 | {
|
---|
336 | switch (value)
|
---|
337 | {
|
---|
338 | case eTextAnchoringType.Bottom:
|
---|
339 | return "b";
|
---|
340 | case eTextAnchoringType.Center:
|
---|
341 | return "ctr";
|
---|
342 | case eTextAnchoringType.Distributed:
|
---|
343 | return "dist";
|
---|
344 | case eTextAnchoringType.Justify:
|
---|
345 | return "just";
|
---|
346 | default:
|
---|
347 | return "t";
|
---|
348 | }
|
---|
349 | }
|
---|
350 | internal static eTextAnchoringType GetTextAchoringEnum(string text)
|
---|
351 | {
|
---|
352 | switch (text)
|
---|
353 | {
|
---|
354 | case "b":
|
---|
355 | return eTextAnchoringType.Bottom;
|
---|
356 | case "ctr":
|
---|
357 | return eTextAnchoringType.Center;
|
---|
358 | case "dist":
|
---|
359 | return eTextAnchoringType.Distributed;
|
---|
360 | case "just":
|
---|
361 | return eTextAnchoringType.Justify;
|
---|
362 | default:
|
---|
363 | return eTextAnchoringType.Top;
|
---|
364 | }
|
---|
365 | }
|
---|
366 | internal static string GetTextVerticalText(eTextVerticalType value)
|
---|
367 | {
|
---|
368 | switch (value)
|
---|
369 | {
|
---|
370 | case eTextVerticalType.EastAsianVertical:
|
---|
371 | return "eaVert";
|
---|
372 | case eTextVerticalType.MongolianVertical:
|
---|
373 | return "mongolianVert";
|
---|
374 | case eTextVerticalType.Vertical:
|
---|
375 | return "vert";
|
---|
376 | case eTextVerticalType.Vertical270:
|
---|
377 | return "vert270";
|
---|
378 | case eTextVerticalType.WordArtVertical:
|
---|
379 | return "wordArtVert";
|
---|
380 | case eTextVerticalType.WordArtVerticalRightToLeft:
|
---|
381 | return "wordArtVertRtl";
|
---|
382 | default:
|
---|
383 | return "horz";
|
---|
384 | }
|
---|
385 | }
|
---|
386 | internal static eTextVerticalType GetTextVerticalEnum(string text)
|
---|
387 | {
|
---|
388 | switch (text)
|
---|
389 | {
|
---|
390 | case "eaVert":
|
---|
391 | return eTextVerticalType.EastAsianVertical;
|
---|
392 | case "mongolianVert":
|
---|
393 | return eTextVerticalType.MongolianVertical;
|
---|
394 | case "vert":
|
---|
395 | return eTextVerticalType.Vertical;
|
---|
396 | case "vert270":
|
---|
397 | return eTextVerticalType.Vertical270;
|
---|
398 | case "wordArtVert":
|
---|
399 | return eTextVerticalType.WordArtVertical;
|
---|
400 | case "wordArtVertRtl":
|
---|
401 | return eTextVerticalType.WordArtVerticalRightToLeft;
|
---|
402 | default:
|
---|
403 | return eTextVerticalType.Horizontal;
|
---|
404 | }
|
---|
405 | }
|
---|
406 | #region "Internal sizing functions"
|
---|
407 | internal int GetPixelLeft()
|
---|
408 | {
|
---|
409 | ExcelWorksheet ws = _drawings.Worksheet;
|
---|
410 | decimal mdw = ws.Workbook.MaxFontWidth;
|
---|
411 |
|
---|
412 | int pix = 0;
|
---|
413 | for (int col = 0; col < From.Column; col++)
|
---|
414 | {
|
---|
415 | pix += (int)decimal.Truncate(((256 * GetColumnWidth(col + 1) + decimal.Truncate(128 / (decimal)mdw)) / 256) * mdw);
|
---|
416 | }
|
---|
417 | pix += From.ColumnOff / EMU_PER_PIXEL;
|
---|
418 | return pix;
|
---|
419 | }
|
---|
420 | internal int GetPixelTop()
|
---|
421 | {
|
---|
422 | ExcelWorksheet ws = _drawings.Worksheet;
|
---|
423 | int pix = 0;
|
---|
424 | for (int row = 0; row < From.Row; row++)
|
---|
425 | {
|
---|
426 | pix += (int)(GetRowWidth(row + 1) / 0.75);
|
---|
427 | }
|
---|
428 | pix += From.RowOff / EMU_PER_PIXEL;
|
---|
429 | return pix;
|
---|
430 | }
|
---|
431 | internal int GetPixelWidth()
|
---|
432 | {
|
---|
433 | ExcelWorksheet ws = _drawings.Worksheet;
|
---|
434 | decimal mdw = ws.Workbook.MaxFontWidth;
|
---|
435 |
|
---|
436 | int pix = -From.ColumnOff / EMU_PER_PIXEL;
|
---|
437 | for (int col = From.Column + 1; col <= To.Column; col++)
|
---|
438 | {
|
---|
439 | pix += (int)decimal.Truncate(((256 * GetColumnWidth(col) + decimal.Truncate(128 / (decimal)mdw)) / 256) * mdw);
|
---|
440 | }
|
---|
441 | pix += To.ColumnOff / EMU_PER_PIXEL;
|
---|
442 | return pix;
|
---|
443 | }
|
---|
444 | internal int GetPixelHeight()
|
---|
445 | {
|
---|
446 | ExcelWorksheet ws = _drawings.Worksheet;
|
---|
447 |
|
---|
448 | int pix = -(From.RowOff / EMU_PER_PIXEL);
|
---|
449 | for (int row = From.Row + 1; row <= To.Row; row++)
|
---|
450 | {
|
---|
451 | pix += (int)(GetRowWidth(row) / 0.75);
|
---|
452 | }
|
---|
453 | pix += To.RowOff / EMU_PER_PIXEL;
|
---|
454 | return pix;
|
---|
455 | }
|
---|
456 |
|
---|
457 | private decimal GetColumnWidth(int col)
|
---|
458 | {
|
---|
459 | ExcelWorksheet ws = _drawings.Worksheet;
|
---|
460 | var column = ws._values.GetValue(0, col) as ExcelColumn;
|
---|
461 | if (column == null) //Check that the column exists
|
---|
462 | {
|
---|
463 | return (decimal)ws.DefaultColWidth;
|
---|
464 | }
|
---|
465 | else
|
---|
466 | {
|
---|
467 | return (decimal)ws.Column(col).VisualWidth;
|
---|
468 | }
|
---|
469 | }
|
---|
470 | private double GetRowWidth(int row)
|
---|
471 | {
|
---|
472 | ExcelWorksheet ws = _drawings.Worksheet;
|
---|
473 | object o = null;
|
---|
474 | if (ws._values.Exists(row, 0, ref o) && o != null) //Check that the row exists
|
---|
475 | {
|
---|
476 | var internalRow = (RowInternal)o;
|
---|
477 | if (internalRow.Height >= 0)
|
---|
478 | {
|
---|
479 | return internalRow.Height;
|
---|
480 | }
|
---|
481 | }
|
---|
482 | return (double)ws.DefaultRowHeight;
|
---|
483 | }
|
---|
484 | internal void SetPixelTop(int pixels)
|
---|
485 | {
|
---|
486 | ExcelWorksheet ws = _drawings.Worksheet;
|
---|
487 | decimal mdw = ws.Workbook.MaxFontWidth;
|
---|
488 | int prevPix = 0;
|
---|
489 | int pix = (int)(GetRowWidth(1) / 0.75);
|
---|
490 | int row = 2;
|
---|
491 |
|
---|
492 | while (pix < pixels)
|
---|
493 | {
|
---|
494 | prevPix = pix;
|
---|
495 | pix += (int)(GetRowWidth(row++) / 0.75);
|
---|
496 | }
|
---|
497 |
|
---|
498 | if (pix == pixels)
|
---|
499 | {
|
---|
500 | From.Row = row - 1;
|
---|
501 | From.RowOff = 0;
|
---|
502 | }
|
---|
503 | else
|
---|
504 | {
|
---|
505 | From.Row = row - 2;
|
---|
506 | From.RowOff = (pixels - prevPix) * EMU_PER_PIXEL;
|
---|
507 | }
|
---|
508 | }
|
---|
509 | internal void SetPixelLeft(int pixels)
|
---|
510 | {
|
---|
511 | ExcelWorksheet ws = _drawings.Worksheet;
|
---|
512 | decimal mdw = ws.Workbook.MaxFontWidth;
|
---|
513 | int prevPix = 0;
|
---|
514 | int pix = (int)decimal.Truncate(((256 * GetColumnWidth(1) + decimal.Truncate(128 / (decimal)mdw)) / 256) * mdw);
|
---|
515 | int col = 2;
|
---|
516 |
|
---|
517 | while (pix < pixels)
|
---|
518 | {
|
---|
519 | prevPix = pix;
|
---|
520 | pix += (int)decimal.Truncate(((256 * GetColumnWidth(col++) + decimal.Truncate(128 / (decimal)mdw)) / 256) * mdw);
|
---|
521 | }
|
---|
522 | if (pix == pixels)
|
---|
523 | {
|
---|
524 | From.Column = col - 1;
|
---|
525 | From.ColumnOff = 0;
|
---|
526 | }
|
---|
527 | else
|
---|
528 | {
|
---|
529 | From.Column = col - 2;
|
---|
530 | From.ColumnOff = (pixels - prevPix) * EMU_PER_PIXEL;
|
---|
531 | }
|
---|
532 | }
|
---|
533 | internal void SetPixelHeight(int pixels)
|
---|
534 | {
|
---|
535 | SetPixelHeight(pixels, STANDARD_DPI);
|
---|
536 | }
|
---|
537 | internal void SetPixelHeight(int pixels, float dpi)
|
---|
538 | {
|
---|
539 | ExcelWorksheet ws = _drawings.Worksheet;
|
---|
540 | //decimal mdw = ws.Workbook.MaxFontWidth;
|
---|
541 | pixels = (int)(pixels / (dpi / STANDARD_DPI) + .5);
|
---|
542 | int pixOff = pixels - ((int)(ws.Row(From.Row + 1).Height / 0.75) - (int)(From.RowOff / EMU_PER_PIXEL));
|
---|
543 | int prevPixOff = pixels;
|
---|
544 | int row = From.Row + 1;
|
---|
545 |
|
---|
546 | while (pixOff >= 0)
|
---|
547 | {
|
---|
548 | prevPixOff = pixOff;
|
---|
549 | pixOff -= (int)(GetRowWidth(++row) / 0.75);
|
---|
550 | }
|
---|
551 | To.Row = row - 1;
|
---|
552 | if (From.Row == To.Row)
|
---|
553 | {
|
---|
554 | To.RowOff = From.RowOff + (pixels) * EMU_PER_PIXEL;
|
---|
555 | }
|
---|
556 | else
|
---|
557 | {
|
---|
558 | To.RowOff = prevPixOff * EMU_PER_PIXEL;
|
---|
559 | }
|
---|
560 | }
|
---|
561 | internal void SetPixelWidth(int pixels)
|
---|
562 | {
|
---|
563 | SetPixelWidth(pixels, STANDARD_DPI);
|
---|
564 | }
|
---|
565 | internal void SetPixelWidth(int pixels, float dpi)
|
---|
566 | {
|
---|
567 | ExcelWorksheet ws = _drawings.Worksheet;
|
---|
568 | decimal mdw = ws.Workbook.MaxFontWidth;
|
---|
569 |
|
---|
570 | pixels = (int)(pixels / (dpi / STANDARD_DPI) + .5);
|
---|
571 | int pixOff = (int)pixels - ((int)decimal.Truncate(((256 * GetColumnWidth(From.Column + 1) + decimal.Truncate(128 / (decimal)mdw)) / 256) * mdw) - From.ColumnOff / EMU_PER_PIXEL);
|
---|
572 | int prevPixOff = From.ColumnOff / EMU_PER_PIXEL + (int)pixels;
|
---|
573 | int col = From.Column + 2;
|
---|
574 |
|
---|
575 | while (pixOff >= 0)
|
---|
576 | {
|
---|
577 | prevPixOff = pixOff;
|
---|
578 | pixOff -= (int)decimal.Truncate(((256 * GetColumnWidth(col++) + decimal.Truncate(128 / (decimal)mdw)) / 256) * mdw);
|
---|
579 | }
|
---|
580 |
|
---|
581 | To.Column = col - 2;
|
---|
582 | To.ColumnOff = prevPixOff * EMU_PER_PIXEL;
|
---|
583 | }
|
---|
584 | #endregion
|
---|
585 | #region "Public sizing functions"
|
---|
586 | /// <summary>
|
---|
587 | /// Set the top left corner of a drawing.
|
---|
588 | /// Note that resizing columns / rows after using this function will effect the position of the drawing
|
---|
589 | /// </summary>
|
---|
590 | /// <param name="PixelTop">Top pixel</param>
|
---|
591 | /// <param name="PixelLeft">Left pixel</param>
|
---|
592 | public void SetPosition(int PixelTop, int PixelLeft)
|
---|
593 | {
|
---|
594 | int width = GetPixelWidth();
|
---|
595 | int height = GetPixelHeight();
|
---|
596 |
|
---|
597 | SetPixelTop(PixelTop);
|
---|
598 | SetPixelLeft(PixelLeft);
|
---|
599 |
|
---|
600 | SetPixelWidth(width);
|
---|
601 | SetPixelHeight(height);
|
---|
602 | }
|
---|
603 | /// <summary>
|
---|
604 | /// Set the top left corner of a drawing.
|
---|
605 | /// Note that resizing columns / rows after using this function will effect the position of the drawing
|
---|
606 | /// </summary>
|
---|
607 | /// <param name="Row">Start row</param>
|
---|
608 | /// <param name="RowOffsetPixels">Offset in pixels</param>
|
---|
609 | /// <param name="Column">Start Column</param>
|
---|
610 | /// <param name="ColumnOffsetPixels">Offset in pixels</param>
|
---|
611 | public void SetPosition(int Row, int RowOffsetPixels, int Column, int ColumnOffsetPixels)
|
---|
612 | {
|
---|
613 | int width = GetPixelWidth();
|
---|
614 | int height = GetPixelHeight();
|
---|
615 |
|
---|
616 | From.Row = Row;
|
---|
617 | From.RowOff = RowOffsetPixels * EMU_PER_PIXEL;
|
---|
618 | From.Column = Column;
|
---|
619 | From.ColumnOff = ColumnOffsetPixels * EMU_PER_PIXEL;
|
---|
620 |
|
---|
621 | SetPixelWidth(width);
|
---|
622 | SetPixelHeight(height);
|
---|
623 | }
|
---|
624 | /// <summary>
|
---|
625 | /// Set size in Percent
|
---|
626 | /// Note that resizing columns / rows after using this function will effect the size of the drawing
|
---|
627 | /// </summary>
|
---|
628 | /// <param name="Percent"></param>
|
---|
629 | public virtual void SetSize(int Percent)
|
---|
630 | {
|
---|
631 | int width = GetPixelWidth();
|
---|
632 | int height = GetPixelHeight();
|
---|
633 |
|
---|
634 | width = (int)(width * ((decimal)Percent / 100));
|
---|
635 | height = (int)(height * ((decimal)Percent / 100));
|
---|
636 |
|
---|
637 | SetPixelWidth(width, 96);
|
---|
638 | SetPixelHeight(height, 96);
|
---|
639 | }
|
---|
640 | /// <summary>
|
---|
641 | /// Set size in pixels
|
---|
642 | /// Note that resizing columns / rows after using this function will effect the size of the drawing
|
---|
643 | /// </summary>
|
---|
644 | /// <param name="PixelWidth">Width in pixels</param>
|
---|
645 | /// <param name="PixelHeight">Height in pixels</param>
|
---|
646 | public void SetSize(int PixelWidth, int PixelHeight)
|
---|
647 | {
|
---|
648 | SetPixelWidth(PixelWidth);
|
---|
649 | SetPixelHeight(PixelHeight);
|
---|
650 | }
|
---|
651 | #endregion
|
---|
652 | internal virtual void DeleteMe()
|
---|
653 | {
|
---|
654 | TopNode.ParentNode.RemoveChild(TopNode);
|
---|
655 | }
|
---|
656 |
|
---|
657 | public virtual void Dispose()
|
---|
658 | {
|
---|
659 | _topNode = null;
|
---|
660 | }
|
---|
661 | }
|
---|
662 | }
|
---|