An (easy) graphical library.
Project description
Documentation for the PyDraw Game Engine(PGE)
[!NOTE] PyDraw is now an GAME ENGINE! Also it's leaving W.I.P(Pre-Release) in version 1.5, so expect a lot of new features and optimizations, and of course, a more stable experience! Also since there are so many projects named PyDraw, submit your idea for a new name: https://forms.gle/8p6pJ7tybQe94ENC8
[!WARNING] The GitHub versions are used ONLY for showing what has changed, its NOT recomanded to install PyDraw from them, use
pipinstead. v1.0.0 ispipexclusive. Please don't. I am using the releases just to note the changelogs.
I - Capabilities and installation:
- Primitives(basic shapes): Squares, Circles, Triangles, and more, with their geometrical operations(area, perrimeter, etc)
- Custom shapes(via Vertex): Since PyDraw is based on the Vertex(basic x and y coodronates), you can make Polygons(with an unlimited nr of Vertexes), or an VertexSquare(an square made of vertexes)
- Motion, basic physics and collisions: The Vertex also helps with collisions, making every shape you do colide(of course, only moveable ones). You just define a shape, then you can move/rotate it or resize it!
- Keyboard Input: The library supports listening for keyboard input, allowing you to create interactive applications.
- Sound: The library also has a sound module that can play WAV files natively, and can decode and play other formats with FFmpeg installed.
- Fast updates: i am updating this library quite often! Especially bugfixes, my ahh can't make some nice code. Bugfixes will be part of most updates, so you can enjoy the smoothest, most stable experience! also we have issues so you can report bugs/suggestions there.
II - Installation
- Via
.url: Open the latest release, run the .url file and run the command from the site. - Via
pip: runpip install pydraw-turtle, andpip install --upgrade pydraw-turtlefor updating.
[!IMPORTANT] Due to me having a severe skill issue, the dependencies might not install. idk why. So, for now on, every release will have the
requirements.txtwith the list of dependencies. Just install them, and PyDraw will work perfectly fine and dandy.
III - How2Use:
1. Shapes and their initialisations(one with ※ can be used with the Motion class):
In PyDraw, all shapes rely on the crucial Vertex. It is an uni-dimensional imaginary dot with an set of coordonates, from where all primitives are based!
And in version 1.3.5, the Cluster has been added(and the list specifies what shapes are Cluster-compatible) that is an array of Vertex elements.
The methods Cluster has are:
from_list(list[Vertex])- Converts an List full of vertexes into anClusteradd(v: Vertex)- Adds anVertexremove(index: int)- Removes anVertexfrom an index.pop(index: int)- Removes and returns anVertexfrom an index.shift_to(index: int, vx: float, vy: float)andshift_by(same arguments- Moves to/by anVertexfrom an index)
List of shapes and their initialisations:
- ※
Line:line = Line(v1: Vertex, v2: Vertex/vertexes: Cluster) - ※
Vertex:vertex = Vertex(x: float, y: float) Circle:circle = Circle(center: Vertex, radius: float)- ※
Triangle:triangle = Triangle(v1: Vertex, v2: Vertex, v3: Vertex/vertexes: Cluster) - ※
Square:square = Square(side: int) - ※(formerly VertexSquare)
CustomSquare:vsquare = CustomSquare(v1: Vertex, v2: Vertex, v3: Vertex, v4: Vertex/vertexes: Cluster) (has been depricated and removed prior to v1.3.5, because its lowk useless.)Elipse:elipse = Elipse(center: Vertex, a: float, b: float)- ※(formerly RegularPolygon)
SidePolygon(n-sided shape):rpoly = SidePolygon(sides: int, side_lenght: float) - ※(formerly Polygon)
Mesh:poly = Mesh(vertecies: list/vertecies: Cluster)(make a list full of vertecies)
2. Functions:
(all shapes exept vertex have get_vertices())
-
Vertex:
getvX();getvY() -
Line:
lenght();midpoint(),slope() -
Circle:
getX();getY();getRadius();area();circ();diam();contains_point(v1: Vertex) -
Triangle:
side_lenghts();perimeter();area();is_equilateral();is_isosceles();is_right() -
Square:
area();perimeter();diagonal() -
VertexSquare:
area();perimeter() -
Ellipse:area();approx_perimeter();contains_point(v1: Vertex) -
RegularPolygon:
perimeter();interior_angle();apothem();area() -
Polygon:
area()
3. Importing:
You can import all the things PyDraw has by writing from pydraw import * (not avabile for versions prior to 1.3.2)
If your version is 1.3.1, then write from pydraw import <what component you would want>
And if your version is prior to 1.3.1, write from core import <what component you would want to import>
4. Movement:
PyDraw also suports movement, using the Motion class. To initialise the Motion class with an shape that is Movable, do:
mov = Motion(shape, pen, vx, vy, colidable, CanExitWindow)
What they mean:
-
shape- Any shape that isMoveable. -
pen: PyPen- AnPyPeninstance. -
vx: floatandvy: float- The initial coordonates. -
colidable: List- An list of shapes that the current shape CAN colide(if you don't set it, it will default to None). -
CanExitWindow: Bool- If the shape colides with the window corner. -
For 1.3.1 and above: Use the Motion class, with the functions:
-
move_to(vx: float, vy: float); -
move_by(vx: float, vy: float); -
set_velocity(vx: float, vy: float); -
accelerate(ax: float, ay: float); -
stop(); -
check_edge_collision(); -
is_on_screen(); -
update().
Example code:
from pydraw import *
pen = PyPen("square chaos")
pen.initialise("white", 2, Speed.INSTANT, "black")
# ── squares ─────────────────────────────
s1 = Square(50)
s1.move_to(-100, -50)
s2 = Square(40)
s2.move_to(80, 60)
s3 = Square(70)
s3.move_to(0, 0)
# ── motion ──────────────────────────────
m1 = Motion(s1, pen, vx=3, vy=2, CanExitWindow=False)
m2 = Motion(s2, pen, vx=-2, vy=3.5, CanExitWindow=False)
m3 = Motion(s3, pen, vx=1.5, vy=-2.5, CanExitWindow=False)
# ── loop ────────────────────────────────
while True:
pen.clear()
pen.draw(s1,color="white",fill=True)
pen.draw(s2,color="red",fill=True)
pen.draw(s3,color="blue",fill=True)
m1.update()
m2.update()
m3.update()
- For version 1.2.0 use the
Moveableclass, that has the same movement commands asMotion, but whiout the collision stuff, and of course, whiout updating(you need to do it manually via pen.clear() ).
Example code:
import os
import sys
from core import PyPen, Square, Triangle, Vertex, Moveable
from turtle import *
import time
pen = PyPen("dvd!")
pen.initialise("black", 1, 1)
cube = Square(60).move_to(100, 100)
dx, dy = 3, 2 # velocity (speed in x and y)
while True:
pen.clear()
# move cube
cube.move_by(dx, dy)
x, y = cube.position
size = cube.side
# screen bounds (you may tweak these depending on your window)
left, right = -395, 395
bottom, top = -330, 330
# bounce logic
if x < left or x + size > right:
dx *= -1
if y < bottom or y + size > top:
dy *= -1
pen.draw(cube, color="purple", fill=True)
pen.screen.update()
time.sleep(0.01)
[!TIP] If you need to transition from
MoveabletoMotion, you just need to addmov = Motion(shape, pen, vx and vy), and it will automaticly change fromMoveabletoMotion. And yes if you wantMoveableinstead ofMotionjust don't initialise it. its called backwards compatability :D (i think)
IV - Sound:
PyDraw has a sound module, that can play WAV files natively, and can decode and play other formats with FFmpeg installed. You can use the Speakers class to play audio
files. Just create an instance of Speakers with the path to your audio file, and call the play() method to play it. If your file is not a WAV file, you can call the decode() method first with the appropriate file type (e.g., "mp3", "ogg", etc.) to decode it into memory before playing.
Example code:
from pydraw import Speakers
speaker = Speakers("path/to/your/audiofile.mp3")
speaker.decode("mp3")
speaker.play()
V - Keyboard input:
PyDraw also has a keyboard module that allows you to listen to keyboard input. You can use the Keyboard class to listen for key presses. Just create an instance of Keyboard, and call the start_listening() method to start listening for keyboard input. You can also specify a callback function that will be called whenever a key is pressed.
Example code:
from pydraw import Keyboard
kb = Keyboard()
kb.start_listening()
while True:
if kb.is_pressed(pynput.keyboard.Key.space):
print(True)
else:
print(False)
VI - Contribuiting and reporting bugs:
You can tell me what issues PyDraw has(because i don't test it too often), by going into the issues section of GitHub. Also, you can suggest me some new ideas there too. Forking is allowed, and you can fork freely, and even merge with the main repo. But if you make your own fork, be sure to give credit.
Made with 💔- ugh i mean 💖 by Brickboss <3
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pydraw_turtle-1.3.6.tar.gz.
File metadata
- Download URL: pydraw_turtle-1.3.6.tar.gz
- Upload date:
- Size: 25.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d1437cf90e6d3ede0d9a117f73c8b0cabffe0146c2127d8dcd96320f0de4249c
|
|
| MD5 |
ff6192af8eed6250c1588b14673400d8
|
|
| BLAKE2b-256 |
60c541a2ebb83ce76d4c2826fbfc0f7323ca4031f95540b6ba60345a2caac4a0
|
File details
Details for the file pydraw_turtle-1.3.6-py3-none-any.whl.
File metadata
- Download URL: pydraw_turtle-1.3.6-py3-none-any.whl
- Upload date:
- Size: 23.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
03ad169e507363ede5c4af0b9e36d5974c219570e894b115836d8218db655c9c
|
|
| MD5 |
d51e84ca74da17b72dad2e66d3b98a57
|
|
| BLAKE2b-256 |
2947a624b505d572dcc0a78820901b9d49badb1b4bd58c3693e31b0bb6fd4931
|