Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/testica/bitmap-ts
Bitmap loader + transformations + filters in Typescript (RequireJS)
https://github.com/testica/bitmap-ts
bitmap canvas typescript
Last synced: 23 days ago
JSON representation
Bitmap loader + transformations + filters in Typescript (RequireJS)
- Host: GitHub
- URL: https://github.com/testica/bitmap-ts
- Owner: testica
- Created: 2016-09-19T23:02:30.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2018-09-28T14:04:29.000Z (over 6 years ago)
- Last Synced: 2024-11-12T16:52:14.688Z (2 months ago)
- Topics: bitmap, canvas, typescript
- Language: JavaScript
- Homepage:
- Size: 103 KB
- Stars: 1
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# bitmap-ts
Library built in [Typescript](https://www.typescriptlang.org/) to load/handle a bitmap file.
Support 1, 2, 4, 8, 16(no tested) and 24 bpp.
The following functions are available:
- read(File)
- negative()
- rotate90CW()
- rotate90CCW()
- rotate180()
- rotate270CW()
- rotate270CCW()
- horizontalFlip()
- verticalFlip()
- drawOnCanvas(canvas)
- drawHistogram(canvas_r, canvas_g, canvas_b, canvas_avg)
- brightness(value)
- contrast(value)
- equalization()
- umbralization(min, max)
- saveFile(callback)
- scale(width, height, 'interpolation|neighbor')
- drawOnCanvasWithZoom (canvas, zoomValue, 'interpolation|neighbor')
- rotate(angle)
- kernel(width, height, customKernel?)
- blur('box|gauss')
- edge('prewitt|sobel')
- outline(boolean)
- customFilter()
- undo() : boolean
- redo() : boolean### How to use
I prepared a code to interact with library, you only need to clone the repository, and open `index.html` in **src/views/**, using a modern browser.
The same view is located on github repository page, [mentioned in the end of this markdown](#demo).To use the library in your own context, only need:
Import in your typescript file the library:
```javascript
import {Bitmap} from "./bitmap";
```Call the constructor and read:
```javascript
let bmp: Bitmap = new Bitmap(file);
// file is a File Type
bmp.read(file, (b: Bitmap) => {
// bmp and b is the same instance
// The file was read. Now, you can use the functions
});
```
And that's all.##### Drawing on Canvas:
Every time that you want to see the changes on your canvas, you have to call `drawOnCanvas(canvas)`
```javascript
let canvas = document.getElementById("canvas_id");
let bmp: Bitmap = new Bitmap(file);
bmp.read(file, (b: Bitmap) => {
b.drawOnCanvas(canvas);
});
```
Also, is important to specify a size of you canvas:
```html```
**NOTE: Canvas can be very slow for big files, it is not the best solution to display a bmp file in HTML. Open a issue if found a faster solution.**##### Drawing Histogram:
Now is possible draw image's histogram, for the moments you have to pass 4 canvas, the first three are for RED, GREEN and BLUE. The last is the average between 3 channels (R, G, B). If the image is grayscale type, only average histogram will be shown. If is the image has color, R,G,B histograms will be shown.
### Dependencies
RequireJS in needed to allow exports and import Bitmap module.
```html```
FileSaver is required, it allows to write a DataView in Blob.
```html```
### Demo
Visit [the github repository page](https://testica.github.io/bitmap3-ts/) to see a demo.----
**Leonardo Testa & Carlos Abreu**