- Notifications
You must be signed in to change notification settings - Fork8
Javascript implementation of Seam Carver. Seam Carver is a content-aware image resizing algorithm
NotificationsYou must be signed in to change notification settings
mfbx9da4/seam-carving-js
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
Javascript implementation of a content-aware image resizing algorithm called seam carving.Seam carving crops an image by removing the "least important" pixels in an image. An "unimportant" pixel is defined as a pixel which is very similar to its surrounding pixels. A seam is a one pixel column in the image which can zig-zag between adjancent columns.
npm install seam-carving-jsOSX requires
brew install pkg-config cairo libpng jpeg giflibxcode-select --install # el capitain onlyUbuntu
sudo apt-get install libcairo2-dev libjpeg8-dev libpango1.0-dev libgif-dev build-essential g++Everyone
npm installgulp buildnpm run testnpm install -g local-web-serverws # navigate to http://localhost:8000- When we remove a seam not all pixels are recalculated instead only pixels either side of the seam are enqueued to be recalculated. If the min sum of the affected pixel has not changed we need not enqueue it's children.
- Move SeamCarver to web worker
- Iterate arrays in a CPU cache efficient way
- Keep track of smallest on top row
- Have three matrices, one for minx, one for vminsum and one for energies so that we can use typed arrays
- Could convert picture rgba array to
Uint32Arrayrgb number array to save space - Do logical deletes on the energy matrix. This way the cost of deletion goes way down, with the cost of finding the neighbor when recalculating going up some. Would have to keep picture array as an array of
Uint8ClampedArrays. - Potentially could add the pixels which we need to recalculate the energy for to a queue of nodes and relax there edges to adjacent pixels. If we do not find a smaller vminsum for any pixel on the queue we do not need to iterate its descendants.
- There might be a (slightly) better way to remove the seam, with less conversion between coordinates.
About
Javascript implementation of Seam Carver. Seam Carver is a content-aware image resizing algorithm
Topics
Resources
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Releases
No releases published
Packages0
No packages published
Uh oh!
There was an error while loading.Please reload this page.

