Proyectos de Subversion Moodle

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1441 ariadna 1
<?php
2
 
3
namespace PhpOffice\PhpSpreadsheet\Writer\Xlsx;
4
 
5
use Composer\Pcre\Preg;
6
use PhpOffice\PhpSpreadsheet\Cell\Coordinate;
7
use PhpOffice\PhpSpreadsheet\Reader\Xlsx\Namespaces;
8
use PhpOffice\PhpSpreadsheet\Shared\Drawing as SharedDrawing;
9
use PhpOffice\PhpSpreadsheet\Shared\XMLWriter;
10
use PhpOffice\PhpSpreadsheet\Spreadsheet;
11
use PhpOffice\PhpSpreadsheet\Worksheet\BaseDrawing;
12
use PhpOffice\PhpSpreadsheet\Worksheet\HeaderFooterDrawing;
13
use PhpOffice\PhpSpreadsheet\Writer\Exception as WriterException;
14
 
15
class Drawing extends WriterPart
16
{
17
    /**
18
     * Write drawings to XML format.
19
     *
20
     * @param bool $includeCharts Flag indicating if we should include drawing details for charts
21
     *
22
     * @return string XML Output
23
     */
24
    public function writeDrawings(\PhpOffice\PhpSpreadsheet\Worksheet\Worksheet $worksheet, bool $includeCharts = false): string
25
    {
26
        // Create XML writer
27
        $objWriter = null;
28
        if ($this->getParentWriter()->getUseDiskCaching()) {
29
            $objWriter = new XMLWriter(XMLWriter::STORAGE_DISK, $this->getParentWriter()->getDiskCachingDirectory());
30
        } else {
31
            $objWriter = new XMLWriter(XMLWriter::STORAGE_MEMORY);
32
        }
33
 
34
        // XML header
35
        $objWriter->startDocument('1.0', 'UTF-8', 'yes');
36
 
37
        // xdr:wsDr
38
        $objWriter->startElement('xdr:wsDr');
39
        $objWriter->writeAttribute('xmlns:xdr', Namespaces::SPREADSHEET_DRAWING);
40
        $objWriter->writeAttribute('xmlns:a', Namespaces::DRAWINGML);
41
 
42
        // Loop through images and write drawings
43
        $i = 1;
44
        $iterator = $worksheet->getDrawingCollection()->getIterator();
45
        while ($iterator->valid()) {
46
            /** @var BaseDrawing $pDrawing */
47
            $pDrawing = $iterator->current();
48
            $pRelationId = $i;
49
            $hlinkClickId = $pDrawing->getHyperlink() === null ? null : ++$i;
50
 
51
            $this->writeDrawing($objWriter, $pDrawing, $pRelationId, $hlinkClickId);
52
 
53
            $iterator->next();
54
            ++$i;
55
        }
56
 
57
        if ($includeCharts) {
58
            $chartCount = $worksheet->getChartCount();
59
            // Loop through charts and write the chart position
60
            if ($chartCount > 0) {
61
                for ($c = 0; $c < $chartCount; ++$c) {
62
                    $chart = $worksheet->getChartByIndex((string) $c);
63
                    if ($chart !== false) {
64
                        $this->writeChart($objWriter, $chart, $c + $i);
65
                    }
66
                }
67
            }
68
        }
69
 
70
        // unparsed AlternateContent
71
        $unparsedLoadedData = $worksheet->getParentOrThrow()->getUnparsedLoadedData();
72
        if (isset($unparsedLoadedData['sheets'][$worksheet->getCodeName()]['drawingAlternateContents'])) {
73
            foreach ($unparsedLoadedData['sheets'][$worksheet->getCodeName()]['drawingAlternateContents'] as $drawingAlternateContent) {
74
                $objWriter->writeRaw($drawingAlternateContent);
75
            }
76
        }
77
 
78
        $objWriter->endElement();
79
 
80
        // Return
81
        return $objWriter->getData();
82
    }
83
 
84
    /**
85
     * Write drawings to XML format.
86
     */
87
    public function writeChart(XMLWriter $objWriter, \PhpOffice\PhpSpreadsheet\Chart\Chart $chart, int $relationId = -1): void
88
    {
89
        $tl = $chart->getTopLeftPosition();
90
        $tlColRow = Coordinate::indexesFromString($tl['cell']);
91
        $br = $chart->getBottomRightPosition();
92
 
93
        $isTwoCellAnchor = $br['cell'] !== '';
94
        if ($isTwoCellAnchor) {
95
            $brColRow = Coordinate::indexesFromString($br['cell']);
96
 
97
            $objWriter->startElement('xdr:twoCellAnchor');
98
 
99
            $objWriter->startElement('xdr:from');
100
            $objWriter->writeElement('xdr:col', (string) ($tlColRow[0] - 1));
101
            $objWriter->writeElement('xdr:colOff', self::stringEmu($tl['xOffset']));
102
            $objWriter->writeElement('xdr:row', (string) ($tlColRow[1] - 1));
103
            $objWriter->writeElement('xdr:rowOff', self::stringEmu($tl['yOffset']));
104
            $objWriter->endElement();
105
            $objWriter->startElement('xdr:to');
106
            $objWriter->writeElement('xdr:col', (string) ($brColRow[0] - 1));
107
            $objWriter->writeElement('xdr:colOff', self::stringEmu($br['xOffset']));
108
            $objWriter->writeElement('xdr:row', (string) ($brColRow[1] - 1));
109
            $objWriter->writeElement('xdr:rowOff', self::stringEmu($br['yOffset']));
110
            $objWriter->endElement();
111
        } elseif ($chart->getOneCellAnchor()) {
112
            $objWriter->startElement('xdr:oneCellAnchor');
113
 
114
            $objWriter->startElement('xdr:from');
115
            $objWriter->writeElement('xdr:col', (string) ($tlColRow[0] - 1));
116
            $objWriter->writeElement('xdr:colOff', self::stringEmu($tl['xOffset']));
117
            $objWriter->writeElement('xdr:row', (string) ($tlColRow[1] - 1));
118
            $objWriter->writeElement('xdr:rowOff', self::stringEmu($tl['yOffset']));
119
            $objWriter->endElement();
120
            $objWriter->startElement('xdr:ext');
121
            $objWriter->writeAttribute('cx', self::stringEmu($br['xOffset']));
122
            $objWriter->writeAttribute('cy', self::stringEmu($br['yOffset']));
123
            $objWriter->endElement();
124
        } else {
125
            $objWriter->startElement('xdr:absoluteAnchor');
126
            $objWriter->startElement('xdr:pos');
127
            $objWriter->writeAttribute('x', '0');
128
            $objWriter->writeAttribute('y', '0');
129
            $objWriter->endElement();
130
            $objWriter->startElement('xdr:ext');
131
            $objWriter->writeAttribute('cx', self::stringEmu($br['xOffset']));
132
            $objWriter->writeAttribute('cy', self::stringEmu($br['yOffset']));
133
            $objWriter->endElement();
134
        }
135
 
136
        $objWriter->startElement('xdr:graphicFrame');
137
        $objWriter->writeAttribute('macro', '');
138
        $objWriter->startElement('xdr:nvGraphicFramePr');
139
        $objWriter->startElement('xdr:cNvPr');
140
        $objWriter->writeAttribute('name', 'Chart ' . $relationId);
141
        $objWriter->writeAttribute('id', (string) (1025 * $relationId));
142
        $objWriter->endElement();
143
        $objWriter->startElement('xdr:cNvGraphicFramePr');
144
        $objWriter->startElement('a:graphicFrameLocks');
145
        $objWriter->endElement();
146
        $objWriter->endElement();
147
        $objWriter->endElement();
148
 
149
        $objWriter->startElement('xdr:xfrm');
150
        $objWriter->startElement('a:off');
151
        $objWriter->writeAttribute('x', '0');
152
        $objWriter->writeAttribute('y', '0');
153
        $objWriter->endElement();
154
        $objWriter->startElement('a:ext');
155
        $objWriter->writeAttribute('cx', '0');
156
        $objWriter->writeAttribute('cy', '0');
157
        $objWriter->endElement();
158
        $objWriter->endElement();
159
 
160
        $objWriter->startElement('a:graphic');
161
        $objWriter->startElement('a:graphicData');
162
        $objWriter->writeAttribute('uri', Namespaces::CHART);
163
        $objWriter->startElement('c:chart');
164
        $objWriter->writeAttribute('xmlns:c', Namespaces::CHART);
165
        $objWriter->writeAttribute('xmlns:r', Namespaces::SCHEMA_OFFICE_DOCUMENT);
166
        $objWriter->writeAttribute('r:id', 'rId' . $relationId);
167
        $objWriter->endElement();
168
        $objWriter->endElement();
169
        $objWriter->endElement();
170
        $objWriter->endElement();
171
 
172
        $objWriter->startElement('xdr:clientData');
173
        $objWriter->endElement();
174
 
175
        $objWriter->endElement();
176
    }
177
 
178
    /**
179
     * Write drawings to XML format.
180
     */
181
    public function writeDrawing(XMLWriter $objWriter, BaseDrawing $drawing, int $relationId = -1, ?int $hlinkClickId = null): void
182
    {
183
        if ($relationId >= 0) {
184
            $isTwoCellAnchor = $drawing->getCoordinates2() !== '';
185
            if ($isTwoCellAnchor) {
186
                // xdr:twoCellAnchor
187
                $objWriter->startElement('xdr:twoCellAnchor');
188
                if ($drawing->validEditAs()) {
189
                    $objWriter->writeAttribute('editAs', $drawing->getEditAs());
190
                }
191
                // Image location
192
                $aCoordinates = Coordinate::indexesFromString($drawing->getCoordinates());
193
                $aCoordinates2 = Coordinate::indexesFromString($drawing->getCoordinates2());
194
 
195
                // xdr:from
196
                $objWriter->startElement('xdr:from');
197
                $objWriter->writeElement('xdr:col', (string) ($aCoordinates[0] - 1));
198
                $objWriter->writeElement('xdr:colOff', self::stringEmu($drawing->getOffsetX()));
199
                $objWriter->writeElement('xdr:row', (string) ($aCoordinates[1] - 1));
200
                $objWriter->writeElement('xdr:rowOff', self::stringEmu($drawing->getOffsetY()));
201
                $objWriter->endElement();
202
 
203
                // xdr:to
204
                $objWriter->startElement('xdr:to');
205
                $objWriter->writeElement('xdr:col', (string) ($aCoordinates2[0] - 1));
206
                $objWriter->writeElement('xdr:colOff', self::stringEmu($drawing->getOffsetX2()));
207
                $objWriter->writeElement('xdr:row', (string) ($aCoordinates2[1] - 1));
208
                $objWriter->writeElement('xdr:rowOff', self::stringEmu($drawing->getOffsetY2()));
209
                $objWriter->endElement();
210
            } else {
211
                // xdr:oneCellAnchor
212
                $objWriter->startElement('xdr:oneCellAnchor');
213
                // Image location
214
                $aCoordinates = Coordinate::indexesFromString($drawing->getCoordinates());
215
 
216
                // xdr:from
217
                $objWriter->startElement('xdr:from');
218
                $objWriter->writeElement('xdr:col', (string) ($aCoordinates[0] - 1));
219
                $objWriter->writeElement('xdr:colOff', self::stringEmu($drawing->getOffsetX()));
220
                $objWriter->writeElement('xdr:row', (string) ($aCoordinates[1] - 1));
221
                $objWriter->writeElement('xdr:rowOff', self::stringEmu($drawing->getOffsetY()));
222
                $objWriter->endElement();
223
 
224
                // xdr:ext
225
                $objWriter->startElement('xdr:ext');
226
                $objWriter->writeAttribute('cx', self::stringEmu($drawing->getWidth()));
227
                $objWriter->writeAttribute('cy', self::stringEmu($drawing->getHeight()));
228
                $objWriter->endElement();
229
            }
230
 
231
            // xdr:pic
232
            $objWriter->startElement('xdr:pic');
233
 
234
            // xdr:nvPicPr
235
            $objWriter->startElement('xdr:nvPicPr');
236
 
237
            // xdr:cNvPr
238
            $objWriter->startElement('xdr:cNvPr');
239
            $objWriter->writeAttribute('id', (string) $relationId);
240
            $objWriter->writeAttribute('name', $drawing->getName());
241
            $objWriter->writeAttribute('descr', $drawing->getDescription());
242
 
243
            //a:hlinkClick
244
            $this->writeHyperLinkDrawing($objWriter, $hlinkClickId);
245
 
246
            $objWriter->endElement();
247
 
248
            // xdr:cNvPicPr
249
            $objWriter->startElement('xdr:cNvPicPr');
250
 
251
            // a:picLocks
252
            $objWriter->startElement('a:picLocks');
253
            $objWriter->writeAttribute('noChangeAspect', '1');
254
            $objWriter->endElement();
255
 
256
            $objWriter->endElement();
257
 
258
            $objWriter->endElement();
259
 
260
            // xdr:blipFill
261
            $objWriter->startElement('xdr:blipFill');
262
 
263
            // a:blip
264
            $objWriter->startElement('a:blip');
265
            $objWriter->writeAttribute('xmlns:r', Namespaces::SCHEMA_OFFICE_DOCUMENT);
266
            $objWriter->writeAttribute('r:embed', 'rId' . $relationId);
267
            $temp = $drawing->getOpacity();
268
            if (is_int($temp) && $temp >= 0 && $temp <= 100000) {
269
                $objWriter->startElement('a:alphaModFix');
270
                $objWriter->writeAttribute('amt', "$temp");
271
                $objWriter->endElement(); // a:alphaModFix
272
            }
273
            $objWriter->endElement(); // a:blip
274
 
275
            $srcRect = $drawing->getSrcRect();
276
            if (!empty($srcRect)) {
277
                $objWriter->startElement('a:srcRect');
278
                foreach ($srcRect as $key => $value) {
279
                    $objWriter->writeAttribute($key, (string) $value);
280
                }
281
                $objWriter->endElement(); // a:srcRect
282
                $objWriter->startElement('a:stretch');
283
                $objWriter->endElement(); // a:stretch
284
            } else {
285
                // a:stretch
286
                $objWriter->startElement('a:stretch');
287
                $objWriter->writeElement('a:fillRect', null);
288
                $objWriter->endElement();
289
            }
290
 
291
            $objWriter->endElement();
292
 
293
            // xdr:spPr
294
            $objWriter->startElement('xdr:spPr');
295
 
296
            // a:xfrm
297
            $objWriter->startElement('a:xfrm');
298
            $objWriter->writeAttribute('rot', (string) SharedDrawing::degreesToAngle($drawing->getRotation()));
299
            self::writeAttributeIf($objWriter, $drawing->getFlipVertical(), 'flipV', '1');
300
            self::writeAttributeIf($objWriter, $drawing->getFlipHorizontal(), 'flipH', '1');
301
            if ($isTwoCellAnchor) {
302
                $objWriter->startElement('a:ext');
303
                $objWriter->writeAttribute('cx', self::stringEmu($drawing->getWidth()));
304
                $objWriter->writeAttribute('cy', self::stringEmu($drawing->getHeight()));
305
                $objWriter->endElement();
306
            }
307
            $objWriter->endElement();
308
 
309
            // a:prstGeom
310
            $objWriter->startElement('a:prstGeom');
311
            $objWriter->writeAttribute('prst', 'rect');
312
 
313
            // a:avLst
314
            $objWriter->writeElement('a:avLst', null);
315
 
316
            $objWriter->endElement();
317
 
318
            if ($drawing->getShadow()->getVisible()) {
319
                // a:effectLst
320
                $objWriter->startElement('a:effectLst');
321
 
322
                // a:outerShdw
323
                $objWriter->startElement('a:outerShdw');
324
                $objWriter->writeAttribute('blurRad', self::stringEmu($drawing->getShadow()->getBlurRadius()));
325
                $objWriter->writeAttribute('dist', self::stringEmu($drawing->getShadow()->getDistance()));
326
                $objWriter->writeAttribute('dir', (string) SharedDrawing::degreesToAngle($drawing->getShadow()->getDirection()));
327
                $objWriter->writeAttribute('algn', $drawing->getShadow()->getAlignment());
328
                $objWriter->writeAttribute('rotWithShape', '0');
329
 
330
                // a:srgbClr
331
                $objWriter->startElement('a:srgbClr');
332
                $objWriter->writeAttribute('val', $drawing->getShadow()->getColor()->getRGB());
333
 
334
                // a:alpha
335
                $objWriter->startElement('a:alpha');
336
                $objWriter->writeAttribute('val', (string) ($drawing->getShadow()->getAlpha() * 1000));
337
                $objWriter->endElement();
338
 
339
                $objWriter->endElement();
340
 
341
                $objWriter->endElement();
342
 
343
                $objWriter->endElement();
344
            }
345
            $objWriter->endElement();
346
 
347
            $objWriter->endElement();
348
 
349
            // xdr:clientData
350
            $objWriter->writeElement('xdr:clientData', null);
351
 
352
            $objWriter->endElement();
353
        } else {
354
            throw new WriterException('Invalid parameters passed.');
355
        }
356
    }
357
 
358
    /**
359
     * Write VML header/footer images to XML format.
360
     *
361
     * @return string XML Output
362
     */
363
    public function writeVMLHeaderFooterImages(\PhpOffice\PhpSpreadsheet\Worksheet\Worksheet $worksheet): string
364
    {
365
        // Create XML writer
366
        $objWriter = null;
367
        if ($this->getParentWriter()->getUseDiskCaching()) {
368
            $objWriter = new XMLWriter(XMLWriter::STORAGE_DISK, $this->getParentWriter()->getDiskCachingDirectory());
369
        } else {
370
            $objWriter = new XMLWriter(XMLWriter::STORAGE_MEMORY);
371
        }
372
 
373
        // XML header
374
        $objWriter->startDocument('1.0', 'UTF-8', 'yes');
375
 
376
        // Header/footer images
377
        $images = $worksheet->getHeaderFooter()->getImages();
378
 
379
        // xml
380
        $objWriter->startElement('xml');
381
        $objWriter->writeAttribute('xmlns:v', Namespaces::URN_VML);
382
        $objWriter->writeAttribute('xmlns:o', Namespaces::URN_MSOFFICE);
383
        $objWriter->writeAttribute('xmlns:x', Namespaces::URN_EXCEL);
384
 
385
        // o:shapelayout
386
        $objWriter->startElement('o:shapelayout');
387
        $objWriter->writeAttribute('v:ext', 'edit');
388
 
389
        // o:idmap
390
        $objWriter->startElement('o:idmap');
391
        $objWriter->writeAttribute('v:ext', 'edit');
392
        $objWriter->writeAttribute('data', '1');
393
        $objWriter->endElement();
394
 
395
        $objWriter->endElement();
396
 
397
        // v:shapetype
398
        $objWriter->startElement('v:shapetype');
399
        $objWriter->writeAttribute('id', '_x0000_t75');
400
        $objWriter->writeAttribute('coordsize', '21600,21600');
401
        $objWriter->writeAttribute('o:spt', '75');
402
        $objWriter->writeAttribute('o:preferrelative', 't');
403
        $objWriter->writeAttribute('path', 'm@4@5l@4@11@9@11@9@5xe');
404
        $objWriter->writeAttribute('filled', 'f');
405
        $objWriter->writeAttribute('stroked', 'f');
406
 
407
        // v:stroke
408
        $objWriter->startElement('v:stroke');
409
        $objWriter->writeAttribute('joinstyle', 'miter');
410
        $objWriter->endElement();
411
 
412
        // v:formulas
413
        $objWriter->startElement('v:formulas');
414
 
415
        // v:f
416
        $objWriter->startElement('v:f');
417
        $objWriter->writeAttribute('eqn', 'if lineDrawn pixelLineWidth 0');
418
        $objWriter->endElement();
419
 
420
        // v:f
421
        $objWriter->startElement('v:f');
422
        $objWriter->writeAttribute('eqn', 'sum @0 1 0');
423
        $objWriter->endElement();
424
 
425
        // v:f
426
        $objWriter->startElement('v:f');
427
        $objWriter->writeAttribute('eqn', 'sum 0 0 @1');
428
        $objWriter->endElement();
429
 
430
        // v:f
431
        $objWriter->startElement('v:f');
432
        $objWriter->writeAttribute('eqn', 'prod @2 1 2');
433
        $objWriter->endElement();
434
 
435
        // v:f
436
        $objWriter->startElement('v:f');
437
        $objWriter->writeAttribute('eqn', 'prod @3 21600 pixelWidth');
438
        $objWriter->endElement();
439
 
440
        // v:f
441
        $objWriter->startElement('v:f');
442
        $objWriter->writeAttribute('eqn', 'prod @3 21600 pixelHeight');
443
        $objWriter->endElement();
444
 
445
        // v:f
446
        $objWriter->startElement('v:f');
447
        $objWriter->writeAttribute('eqn', 'sum @0 0 1');
448
        $objWriter->endElement();
449
 
450
        // v:f
451
        $objWriter->startElement('v:f');
452
        $objWriter->writeAttribute('eqn', 'prod @6 1 2');
453
        $objWriter->endElement();
454
 
455
        // v:f
456
        $objWriter->startElement('v:f');
457
        $objWriter->writeAttribute('eqn', 'prod @7 21600 pixelWidth');
458
        $objWriter->endElement();
459
 
460
        // v:f
461
        $objWriter->startElement('v:f');
462
        $objWriter->writeAttribute('eqn', 'sum @8 21600 0');
463
        $objWriter->endElement();
464
 
465
        // v:f
466
        $objWriter->startElement('v:f');
467
        $objWriter->writeAttribute('eqn', 'prod @7 21600 pixelHeight');
468
        $objWriter->endElement();
469
 
470
        // v:f
471
        $objWriter->startElement('v:f');
472
        $objWriter->writeAttribute('eqn', 'sum @10 21600 0');
473
        $objWriter->endElement();
474
 
475
        $objWriter->endElement();
476
 
477
        // v:path
478
        $objWriter->startElement('v:path');
479
        $objWriter->writeAttribute('o:extrusionok', 'f');
480
        $objWriter->writeAttribute('gradientshapeok', 't');
481
        $objWriter->writeAttribute('o:connecttype', 'rect');
482
        $objWriter->endElement();
483
 
484
        // o:lock
485
        $objWriter->startElement('o:lock');
486
        $objWriter->writeAttribute('v:ext', 'edit');
487
        $objWriter->writeAttribute('aspectratio', 't');
488
        $objWriter->endElement();
489
 
490
        $objWriter->endElement();
491
 
492
        // Loop through images
493
        foreach ($images as $key => $value) {
494
            $this->writeVMLHeaderFooterImage($objWriter, $key, $value);
495
        }
496
 
497
        $objWriter->endElement();
498
 
499
        // Return
500
        return $objWriter->getData();
501
    }
502
 
503
    /**
504
     * Write VML comment to XML format.
505
     *
506
     * @param string $reference Reference
507
     */
508
    private function writeVMLHeaderFooterImage(XMLWriter $objWriter, string $reference, HeaderFooterDrawing $image): void
509
    {
510
        // Calculate object id
511
        if (!Preg::isMatch('{(\d+)}', md5($reference), $m)) {
512
            // @codeCoverageIgnoreStart
513
            throw new WriterException('Regexp failure in writeVMLHeaderFooterImage');
514
            // @codeCoverageIgnoreEnd
515
        }
516
        $id = 1500 + ((int) substr($m[1], 0, 2) * 1);
517
 
518
        // Calculate offset
519
        $width = $image->getWidth();
520
        $height = $image->getHeight();
521
        $marginLeft = $image->getOffsetX();
522
        $marginTop = $image->getOffsetY();
523
 
524
        // v:shape
525
        $objWriter->startElement('v:shape');
526
        $objWriter->writeAttribute('id', $reference);
527
        $objWriter->writeAttribute('o:spid', '_x0000_s' . $id);
528
        $objWriter->writeAttribute('type', '#_x0000_t75');
529
        $objWriter->writeAttribute('style', "position:absolute;margin-left:{$marginLeft}px;margin-top:{$marginTop}px;width:{$width}px;height:{$height}px;z-index:1");
530
 
531
        // v:imagedata
532
        $objWriter->startElement('v:imagedata');
533
        $objWriter->writeAttribute('o:relid', 'rId' . $reference);
534
        $objWriter->writeAttribute('o:title', $image->getName());
535
        $objWriter->endElement();
536
 
537
        // o:lock
538
        $objWriter->startElement('o:lock');
539
        $objWriter->writeAttribute('v:ext', 'edit');
540
        $objWriter->writeAttribute('textRotation', 't');
541
        $objWriter->endElement();
542
 
543
        $objWriter->endElement();
544
    }
545
 
546
    /**
547
     * Get an array of all drawings.
548
     *
549
     * @return BaseDrawing[] All drawings in PhpSpreadsheet
550
     */
551
    public function allDrawings(Spreadsheet $spreadsheet): array
552
    {
553
        // Get an array of all drawings
554
        $aDrawings = [];
555
 
556
        // Loop through PhpSpreadsheet
557
        $sheetCount = $spreadsheet->getSheetCount();
558
        for ($i = 0; $i < $sheetCount; ++$i) {
559
            // Loop through images and add to array
560
            $iterator = $spreadsheet->getSheet($i)->getDrawingCollection()->getIterator();
561
            while ($iterator->valid()) {
562
                $aDrawings[] = $iterator->current();
563
 
564
                $iterator->next();
565
            }
566
        }
567
 
568
        return $aDrawings;
569
    }
570
 
571
    private function writeHyperLinkDrawing(XMLWriter $objWriter, ?int $hlinkClickId): void
572
    {
573
        if ($hlinkClickId === null) {
574
            return;
575
        }
576
 
577
        $objWriter->startElement('a:hlinkClick');
578
        $objWriter->writeAttribute('xmlns:r', Namespaces::SCHEMA_OFFICE_DOCUMENT);
579
        $objWriter->writeAttribute('r:id', 'rId' . $hlinkClickId);
580
        $objWriter->endElement();
581
    }
582
 
583
    private static function stringEmu(int $pixelValue): string
584
    {
585
        return (string) SharedDrawing::pixelsToEMU($pixelValue);
586
    }
587
 
588
    private static function writeAttributeIf(XMLWriter $objWriter, ?bool $condition, string $attr, string $val): void
589
    {
590
        if ($condition) {
591
            $objWriter->writeAttribute($attr, $val);
592
        }
593
    }
594
}