mathematicator-core / vizualizator
Core logic for elegant graphic visualization. Render to SVG, PNG, JPG and Base64.
Installs: 2 950
Dependents: 2
Suggesters: 0
Security: 0
Stars: 5
Watchers: 2
Forks: 2
Open Issues: 4
Requires
- php: ^8.0
- mathematicator-core/numbers: ^2.1
- mathematicator-core/tokenizer: ^2.1 || ^3.0
- nette/utils: ^3.0
Requires (Dev)
- brainmaestro/composer-git-hooks: dev-master
- jetbrains/phpstorm-attributes: ^1.0
- nette/bootstrap: ^3.0
- nette/tester: ^2.3
- phpstan/phpstan: ^0.12.74
- phpstan/phpstan-nette: ^0.12.14
- roave/security-advisories: dev-master
- spaze/phpstan-disallowed-calls: ^1.1
- tracy/tracy: ^2.8
- v3.0.0
- dev-master / 2.2.x-dev
- v2.0.2
- v2.0.1
- v2.0.0
- v1.0.3
- v1.0.2
- v1.0.1
- dev-dependabot/composer/phpstan/phpstan-nette-tw-0.12.14or-tw-1.0.0
- dev-dependabot/composer/phpstan/phpstan-tw-0.12.74or-tw-1.0.0
- dev-dependabot/composer/spaze/phpstan-disallowed-calls-tw-1.1or-tw-3.0
- dev-dependabot/composer/nette/utils-tw-3.0or-tw-4.0
- dev-dependabot/add-v2-config-file
This package is auto-updated.
Last update: 2024-09-10 05:15:50 UTC
README
Smart engine for creating elegant images and graphic visualizations.
Render to SVG, PNG and JPG. All output is in base64 format valid in HTML document.
Installation
composer require mathematicator-core/vizualizator
Usage
Imagine you can render all your images by simple objective request.
First inject Renderer
to your script and create request:
$renderer = new Renderer; $request = $renderer->createRequest();
Now you can add some lines and more:
$request->addLine(10, 10, 35, 70); $request->addLine(35, 70, 70, 35);
And render to page (output is valid HTML code, base64
or svg
tag):
// Render specific format: echo $request->render(Renderer::FORMAT_PNG); echo $request->render(Renderer::FORMAT_JPG); echo $request->render(Renderer::FORMAT_SVG); // Or use default renderer and __toString() method echp $request;
Full simple short example
This example use short fluid-syntax. Final image size is 200x100
:
echo (new Renderer)->createRequest(200, 100) ->addLine(10, 10, 35, 70, '#aaa') ->addLine(35, 70, 70, 35, 'red');
Mathematicator Framework tools structure
The biggest advantage is that you can choose which layer best fits your needs and start build on the top of it, immediately, without the need to create everything by yourself. Our tools are tested for bugs and tuned for performance, so you can save a significant amount of your time, money, and effort.
Framework tend to be modular as much as possible, so you should be able to create an extension on each layer and its sublayers.
Mathematicator framework layers ordered from the most concrete one to the most abstract one:
Third-party packages:
⚠️ Not guaranteed!
Contribution
Tests
All new contributions should have its unit tests in /tests
directory.
Before you send a PR, please, check all tests pass.
This package uses Nette Tester. You can run tests via command:
composer test
Before PR, please run complete code check via command:
composer cs:install # only first time composer fix # otherwise pre-commit hook can fail