Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/guhan-sensam/neukivy
A collection of Neumorphic widgets made with kivy
https://github.com/guhan-sensam/neukivy
android kivy kivy-language neumorphism python3
Last synced: 3 months ago
JSON representation
A collection of Neumorphic widgets made with kivy
- Host: GitHub
- URL: https://github.com/guhan-sensam/neukivy
- Owner: Guhan-SenSam
- License: mit
- Created: 2021-06-22T09:41:14.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2022-02-17T10:47:38.000Z (almost 3 years ago)
- Last Synced: 2024-10-14T06:23:14.608Z (3 months ago)
- Topics: android, kivy, kivy-language, neumorphism, python3
- Language: Python
- Homepage:
- Size: 1.24 MB
- Stars: 30
- Watchers: 4
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# NeuKivy
![demo](https://github.com/Guhan-SenSam/NeuKivy/blob/main/images/demo.png)
Neukivy is a collection of neumorphic widgets built with Kivy. The library is currently in its initial development so there isn't much yet. But hopefully it will grow into a library you can use to easily create neumorphic UI in python.
## How to Install
1. Neukivy requires the latest version of pillow to run. This dependency will eventually be removed.
```
python3 -m pip install --upgrade Pillow
```
Make sure you are running the latest version (8.2.0)2. Now install NeuKivy
```
pip install --upgrade git+git://github.com/Guhan-SenSam/NeuKivy.git
```## Support
[Discord](https://discord.com/channels/943755643741933618/943789595055779850)
## UsageThere is a temporary examples directory that contains some code to help you understand the basic properties of NeuKivy better.
## Things to Know
1. I am just starting! NeuKivy is very young and still needs to grow by a lot to become of any practical use. Right now its more of a proof of concept and a demo rather than an actual usable library.
2. All the properties have doc strings explaining what they do.
3. I would love for your feedback and any ideas that you have for NeuKivy!
## PERFORMANCE PROBLEMS
NeuKivy needs to compute two shadows for every widget that is displayed. A shadow's computation is slow due to the dependency of Pillow. Thus the library has been structured in a way so as to minimize the amount of needed shadow recomputes. As of now when a widget changes size or elevation the shadow is recomputed.
On a PC the impact is negligible but on Android, animations regarding widget sizes is very slow. It might be okay with a couple of small widgets. But anything more will cause frame drops.
Elevation changes do not affect performance as much, but also should not be animated as much as possible.
Currently work is being done to draw the shadows using glsl shaders. This would make redrawing the shadows very fast.
**If you know anything about glsl shaders and creating super fast drop shadow shaders, your contributions are greatly welcome.(As I am not that experienced in glsl and it will take a long time to learn the language and the techniques.)**
To sum everything up. NeuKivy can run on android as long as you don't animate a lot of widget sizes ;)
# Widgets Available
1. Button
- Rectangular
- Rounded Rectangle
- Circular2. Icon Button
- Rectangular
- Rounded Rectangle
- Circular![buttons1](https://github.com/Guhan-SenSam/NeuKivy/blob/main/images/buttons1.png)
3. Icon With Text Button(Can choose which side icon appears)
- Rectangular
- Rounded Rectangle
![buttons2](https://github.com/Guhan-SenSam/NeuKivy/blob/main/images/buttons2.png)4. Card
5. Banner
6. Sliders
![sliders](https://github.com/Guhan-SenSam/NeuKivy/blob/main/images/slider.png)