pixelimgjs/README.md
2023-03-22 20:55:06 +01:00

6.3 KiB

Pixelimg.js

Release License Maintaner

Pixelimg.js is a rather small js-library to display code-generated pixel images inside of an html image-element.

Used at skyicon.drmaxnix.de.

Code examples can be found at the bottom of this README!

Installation

To include Pixelimg.js in your html code you have two options:

  • Either download the pixelimg.js file from the repo and serve it by yourself
  • Or use a CDN

Example using jsdelivr.net:

<script type="text/javascript" src="https://cdn.jsdelivr.net/gh/DrMaxNix/pixelimgjs@1/pixelimg.min.js"></script>

Usage

HTML image element

The only two important parts here are:

  1. The element must be an image <img />
  2. The element should have an id-tag (or any other data-tag) which helps specifying the element later when we will be loading data into the image
<img id="img1" />

Create Pixelimg-object

To be able to work with your image you need to create an object for each of them.

const img1 = new Pixelimg(document.getElementById("img1"), {matrix:8, image:512});

Arguments shown above:

  • matrix The pixel-matrix will have 8 by 8 pixels in size
  • image The png image which is generated will have a size of 512 by 512 pixels (=resolution)

More arguments for the constructor can be found in the Functions section at new Pixelimg(ELEMENT, OPTIONS).

Functions

new Pixelimg(ELEMENT, OPTIONS)

Return a new Pixelimg-object for an ELEMENT with OPTIONS

Arguments

  • ELEMENT: Reference to the img-element to be linked
  • OPTIONS: Named args
    • OPTIONS.matrix Matrix size for width and height
    • OPTIONS.matrix_width Matrix width (only when OPTIONS.matrix not used)
    • OPTIONS.matrix_height Matrix height (only when OPTIONS.matrix not used)
    • OPTIONS.image Image size for width and height for resulting png (=resolution)
    • OPTIONS.image_width Image width (only when OPTIONS.image not used)
    • OPTIONS.image_height Image height (only when OPTIONS.image not used)
    • OPTIONS.autodraw Redraw image every time the matrix is changed; default: false
    • OPTIONS.firstdraw Draw image after the constructor was called; default: true

Returns

A Pixelimg-object

color_from_hex(HEX_STRING)

Get pixelimg-compatible rgba color from css-like hex-color

Arguments

  • HEX_STRING: Hex-color as string
    • eg. #FF0000 -> Red
    • eg. #F8A -> #FF88AA -> Pink-ish
    • eg. #0 -> #000000 -> Black
    • eg. #08 -> #080808 -> A bit lighter than black
    • eg. 0F0 -> #00FF00 -> Green

Returns

A Pixelimg-color-object

color_from_rgba(R, G, B, A)

Get pixelimg-compatible rgba color from rgba-values

Arguments

  • R: Red component; Range: 0-255 (int)
  • G: Green component; Range: 0-255 (int)
  • B: Blue component; Range: 0-255 (int)
  • A: Alpha (opacity); Range: 0.0-1.0 (float)

Returns

A Pixelimg-color-object

set_pixel(OPTIONS)

Set pixel at X, Y to COLOR

Arguments

  • OPTIONS: Named args
    • OPTIONS.x Pixel's x-coordinate; Starting from 0 = furthest left
    • OPTIONS.y Pixel's y-coordinate; Starting from 0 = furthest top
    • OPTIONS.color Color for that pixel (Pixelimg-color-object)

set_matrix(MATRIX)

Update whole matrix from 2d-array

Arguments

draw()

Draw new image from matrix

Color-object

An object storing red, green, blue and alpha data for a color (all Range: 0-255 (int))

{r:255, g:127, b:0, a:255}

How to get it

Examples

1. 2x2 Red, Green, Yellow and Blue pixels

Output

<script type="text/javascript" src="https://cdn.jsdelivr.net/gh/DrMaxNix/pixelimgjs@1/pixelimg.min.js"></script>

<img id="img1" style="width: calc(100vh - 20px); height: calc(100vh - 20px);" />

<script type="text/javascript">
	document.addEventListener("DOMContentLoaded", function(){
		// GET A PIXELIMG-OBJECT FOR IMG WITH ID 'IMG1' //
		const img1 = new Pixelimg(document.getElementById("img1"), {matrix:2, image:2048});
		
		
		// SET PIXELS //
		//generate matrix
		var matrix = [
			[
				Pixelimg.color_from_hex("#F00"),
				Pixelimg.color_from_hex("#0F0")
			], [
				Pixelimg.color_from_hex("#FF0"),
				Pixelimg.color_from_hex("#00F")
			]
		];
		
		//push matrix
		img1.set_matrix(matrix);
		
		
		// DRAW/UPDATE THE IMAGE //
		img1.draw();
	});
</script>

2. 64x64 RGB color-palette

Output

<script type="text/javascript" src="https://cdn.jsdelivr.net/gh/DrMaxNix/pixelimgjs@1/pixelimg.min.js"></script>

<img id="img1" style="width: calc(100vh - 20px); height: calc(100vh - 20px);" />

<script type="text/javascript">
	document.addEventListener("DOMContentLoaded", function(){
		// GET A PIXELIMG-OBJECT FOR IMG WITH ID 'IMG1' //
		const img1 = new Pixelimg(document.getElementById("img1"), {matrix:(16 * 4), image:2048});
		
		
		// SET PIXELS //
		for(var r = 0; r < 16; r++){ //red counter
			//get offsets for this red-intensity's square
			var x_offset = (r % 4) * 16;
			var y_offset = parseInt(r / 4) * 16;
			
			for(var g = 0; g < 16; g++){ //green counter
				for(var b = 0; b < 16; b++){ //blue counter
					//get color components from position
					var color_red = r * (255 / 15);
					var color_green = g * (255 / 15);
					var color_blue = b * (255 / 15);
					
					//get pixel coordinates
					var coord_x = x_offset + g;
					var coord_y = y_offset + b;
					
					//set pixel
					img1.set_pixel({x:coord_x, y:coord_y, color:Pixelimg.color_from_rgba(color_red, color_green, color_blue, 1)});
				}
			}
		}
		
		
		// DRAW/UPDATE THE IMAGE //
		img1.draw();
	});
</script>