Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/shashi278/svg-anim-kivy
SVG path drawing and animation support in kivy application
https://github.com/shashi278/svg-anim-kivy
hacktoberfest kivy python svg svg-animations svg-images
Last synced: 3 months ago
JSON representation
SVG path drawing and animation support in kivy application
- Host: GitHub
- URL: https://github.com/shashi278/svg-anim-kivy
- Owner: shashi278
- License: mit
- Created: 2021-06-09T16:52:23.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-01-20T07:23:49.000Z (about 1 year ago)
- Last Synced: 2024-10-01T08:24:06.063Z (4 months ago)
- Topics: hacktoberfest, kivy, python, svg, svg-animations, svg-images
- Language: Python
- Homepage:
- Size: 542 KB
- Stars: 34
- Watchers: 5
- Forks: 6
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## Kivg
*SVG path drawing and animation support in kivy application*[![build](https://travis-ci.com/shashi278/svg-anim-kivy.svg?branch=main)](https://travis-ci.org/github/shashi278/svg-anim-kivy/) [![Python 3.6](https://img.shields.io/pypi/pyversions/kivymd)](https://www.python.org/downloads/release/python-360/) [![pypi](https://img.shields.io/pypi/v/kivg)](https://pypi.org/project/Kivg/) [![license](https://img.shields.io/github/license/shashi278/svg-anim-kivy)](https://github.com/shashi278/svg-anim-kivy/blob/main/LICENSE) [![downloads](https://img.shields.io/pypi/dm/kivg)](https://pypi.org/project/Kivg/) [![code size](https://img.shields.io/github/languages/code-size/shashi278/svg-anim-kivy)]()
#
## Features
| **Path Drawing & filling** | **Shape Animation** |
| :-------------: |:-------------:|
| | |Now you can take some of the advantages svg offers, in your kivy apps. Those are:
- [x] Compact file size compare to other formats - reduced asset size
- [x] Scalability - Draw them big or small
- [x] Interactivity - Animations#
## Install
```bash
pip install kivg
```## How to use?
- ### Path drawing and filling```python
s = Kivg(my_widget)# call draw method with a `svg_file` name
s.draw("github.svg", fill=False, animate=True, anim_type="seq")```
#### Info:
- **fill** : *Whether to fill the shape after drawing*. Defaults to `True`- **animate** : *Whether to animate drawing*. Defaults to `False`
- **anim_type** : *Whether to draw in sequence or parallel. Available `"seq"` and `"par"`*. Defaults to `"seq"`
#### Important:
- Fill color would only work if it's in hex and inside `` tag. You must modify svg if it's not this way already.- Gradient is not yet supported - default to `#ffffff` if can't parse color
#
- ### Shape Animation
```python
s = Kivg(my_widget)anim_config = [
{ "id_":"k", "from_":"center_x", "t":"out_back", "d":.4 },
{ "id_":"i", "from_":"center_y", "t":"out_bounce", "d":.4 },
{ "id_":"v", "from_":"top", "t":"out_quint", "d":.4 },
{ "id_":"y", "from_":"bottom", "t":"out_back", "d":.4 }
]# call shape_animate method with `svg_file` and an animation config list and optional callback
s.shape_animate("text.svg", anim_config_list=anim_config, on_complete=lambda *args: print("Completed!"))
```
#### Info:
- **anim_config_list** : A list of dicts where each dict contain config for an `id`. Description of each key:
- `"id_"` : `id` of svg `` tag. It's required so each dict must contain `"id_"` key- `"from_"` : Direction from which a path should grow. Accepted values `"left"`, `"right"`, `"top"`, `"bottom"`, `"center_x"`(grow from center along horizontal axis), `"center_y"`, and `None`(Draw without animation). Defaults to `None`.
- `"t"` : [Animation transition](https://kivy.org/doc/stable/api-kivy.animation.html?highlight=animation#kivy.animation.AnimationTransition). Defaults to `"out_sine"`.
- `"d"` : Duration of animation. It'll still in-effect if `"from_"` is set to `None`. Defaults to .3
- **on_complete**(optional) : Function to call after entire animation is finished. It can be used to create looping animation
#### Important:
- You must add a unique `id` to each path element you want to animate- Dict order in the list is important
* See [Demo code](https://github.com/shashi278/svg-anim-kivy/blob/main/demo/main.py)
#### Useful Links:
Few links that I found useful for modifying few svg files in order to work with this library are:* https://itchylabs.com/tools/path-to-bezier/ - Convert SVG Path to Cubic Curves
Use it to convert SVG Arcs to Cubic Bezier. Make sure you paste the entire `path` in the textfield rather than only the arc section. Also you should provide path dimensions(`W` & `H`) on the website as your svg width and height(found under `` tag). You may also need to close each path, i.e. add `Z` at the end of new converted path.
* https://codepen.io/thednp/pen/EgVqLw - Convert Relative SVG Path To Absolute Path
Maybe useful when you want to split a single svg path into multiple paths for animation purpose. Paste the entire path. When splitting, make sure you close the previous path by adding a `Z` at the end in the path string.### Changelog
**v1.1**
* Fixed crashing when SVG size is not int**v1.0**
* Shape animation feature added
* Added `anim_type` in draw method**Earlier Changes**
* Added option to draw image without animation, `animate=False`
* Added option to draw empty or filled path, `fill=True` or `fill=False`### Contribution
![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square)
Whether you found a bug or have some idea to improve the project, PRs are always more than welcome