Charts32DsvGlowTest.php 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. <?php
  2. namespace PhpOffice\PhpSpreadsheetTests\Chart;
  3. use PhpOffice\PhpSpreadsheet\Reader\Xlsx as XlsxReader;
  4. use PhpOffice\PhpSpreadsheet\Writer\Xlsx as XlsxWriter;
  5. use PhpOffice\PhpSpreadsheetTests\Functional\AbstractFunctional;
  6. class Charts32DsvGlowTest extends AbstractFunctional
  7. {
  8. private const DIRECTORY = 'samples' . DIRECTORY_SEPARATOR . 'templates' . DIRECTORY_SEPARATOR;
  9. public function readCharts(XlsxReader $reader): void
  10. {
  11. $reader->setIncludeCharts(true);
  12. }
  13. public function writeCharts(XlsxWriter $writer): void
  14. {
  15. $writer->setIncludeCharts(true);
  16. }
  17. public function testLine4(): void
  18. {
  19. $file = self::DIRECTORY . '32readwriteLineChart4.xlsx';
  20. $reader = new XlsxReader();
  21. $reader->setIncludeCharts(true);
  22. $spreadsheet = $reader->load($file);
  23. $sheet = $spreadsheet->getActiveSheet();
  24. self::assertSame(1, $sheet->getChartCount());
  25. /** @var callable */
  26. $callableReader = [$this, 'readCharts'];
  27. /** @var callable */
  28. $callableWriter = [$this, 'writeCharts'];
  29. $reloadedSpreadsheet = $this->writeAndReload($spreadsheet, 'Xlsx', $callableReader, $callableWriter);
  30. $spreadsheet->disconnectWorksheets();
  31. $sheet = $reloadedSpreadsheet->getActiveSheet();
  32. $charts = $sheet->getChartCollection();
  33. self::assertCount(1, $charts);
  34. $chart = $charts[0];
  35. self::assertNotNull($chart);
  36. $plotArea = $chart->getPlotArea();
  37. self::assertNotNull($plotArea);
  38. $dataSeriesArray = $plotArea->getPlotGroup();
  39. self::assertCount(1, $dataSeriesArray);
  40. $dataSeries = $dataSeriesArray[0];
  41. $dataSeriesValuesArray = $dataSeries->getPlotValues();
  42. self::assertCount(3, $dataSeriesValuesArray);
  43. $dataSeriesValues = $dataSeriesValuesArray[1];
  44. self::assertEquals(5, $dataSeriesValues->getGlowSize());
  45. self::assertSame('schemeClr', $dataSeriesValues->getGlowProperty(['color', 'type']));
  46. self::assertSame('accent2', $dataSeriesValues->getGlowProperty(['color', 'value']));
  47. self::assertSame(60, $dataSeriesValues->getGlowProperty(['color', 'alpha']));
  48. $yAxis = $chart->getChartAxisY();
  49. $majorGridlines = $yAxis->getMajorGridlines();
  50. self::assertNotNull($majorGridlines);
  51. self::assertSame('triangle', $majorGridlines->getLineStyleProperty(['arrow', 'head', 'type']));
  52. self::assertSame('triangle', $majorGridlines->getLineStyleProperty(['arrow', 'end', 'type']));
  53. $minorGridlines = $yAxis->getMinorGridlines();
  54. self::assertNotNull($minorGridlines);
  55. self::assertSame('sysDot', $minorGridlines->getLineStyleProperty('dash'));
  56. self::assertSame('FFC000', $minorGridlines->getLineColor()->getValue());
  57. $xAxis = $chart->getChartAxisX();
  58. $majorGridlines = $xAxis->getMajorGridlines();
  59. $minorGridlines = $xAxis->getMinorGridlines();
  60. self::assertNotNull($majorGridlines);
  61. self::assertSame('7030A0', $majorGridlines->getLineColor()->getValue());
  62. self::assertNotNull($minorGridlines);
  63. self::assertFalse($minorGridlines->getLineColor()->isUsable());
  64. $reloadedSpreadsheet->disconnectWorksheets();
  65. }
  66. }