GitXplorerGitXplorer
j

canvas

public
7 stars
1 forks
0 issues

Commits

List of commits on branch master.
Verified
ac24b674df6c7b627a0119e649591ef92e5ec340

Update README.md

jjerr-it committed 3 years ago
Unverified
f4a65670ec245ffb5c24c56611228612731291c8

Formatting

jjerr-it committed 4 years ago
Unverified
c2947c3488a632c9f70a80ae51e90ce115c0477e

Adjusted code for pedantic compiling

jjerr-it committed 4 years ago
Unverified
c6435f733ab06b31ed3f8b9829850abc2503a284

Added clear art function

jjerr-it committed 4 years ago
Unverified
b07f9aaa9881ea4be4acb88280a88ded0f7468d4

Readme correction

jjerr-it committed 4 years ago
Unverified
df57e981ad4e5bd7f5250c53ac4f014d794edfc3

Updated Readme

jjerr-it committed 4 years ago

README

The README file for this repository.

Canvas


Library for rendering images and videos directly using C and the NetPBM image format

How to use

Compile repo:

make 
./render

or 
g++ -o render main.cpp Artwork/Color.h Artwork/Artwork.h Artwork/Artwork.c
./render

Examples

Check main.cpp!

Include header:

#include "Artwork/Artwork.h"

Create artwork and set values:

Artwork art = newArt(400, 400);

Dont forget to free afterwards to avoid memory leaks!

freeArt(art);

Set color scheme with stroke, fill and stroke width:

art.strokeColor = Color { 255, 0, 0 };
art.strokeWidth = 5;

art.fillColor = Color { 200, 200, 200 };

Set individual pixel

setPixel(art, <x>, <y>, Color {255, 255, 255});

Draw line (color determined by stroke color):

drawLine(art, <x0>, <y0>, <x1>, <y1>);

Draw rect:

drawRect(art, <top-left x>, <top-left y>, <width>, <height>);

Draw circle:

drawCircle(art, <x>, <y>, <radius>);

Draw ellipse:

drawEllipse(art, <x>, <y>, <x-radius>, <y-radius>);

Clear artwork / fill it entirely_

clear(art, Color { 0, 0, 0 });

Save as a single image:

char filename[] = "nicePic.ppm";
saveArt(art, filename);

Pipe it out (necessary for video creation):

pipeArtTo(art, stdout);

Pipe it to VLC:

./ExecutableNameHere | ppmtoy4m -F60:1 | vlc -

Or render the complete video:

./ExecutableNameHere | ffmpeg -i pipe:0 -c:v libx264rgb VideoName.avi

SFML Tandem

The SFML_Artwork class is essentially a C++ wrapper for the standard rendering. It enables you to create Artworks from sf::Image objects, the entire window for example.

#include "SFML_Artwork/SFML_Artwork.h"

Create your window and rendering:

RenderWindow window(VideoMode(800, 800), "Rendering");
Rendering* rendering = createRendering(800, 800);

Texture texture;
Image image;
Vector2u windowsize;

Save your window as an image:

windowsize = window.getSize();
texture.create(windowsize.x, windowsize.y);
texture.update(window);
image = texture.copyToImage();
Artwork art = SFML_Artwork::fromImage(image);
saveArt(art);