I am passionate about generative art and enjoy creating unusual projects with p5.js. I'm also passionate about Flutter, and I had the idea to combine both directions. Especially since I haven't found similar projects that include an ASCII camera, which made the task even more interesting to realise.
To implement this project I used the camera package and ASCII characters. The project works as follows ⬇️
- ASCII Drawing: the
ASCIIPainter
class is responsible for converting an image into ASCII art. - Cell Partitioning: the image is divided into a grid of n x m cells.
- Converting pixels to characters: for each cell:
- The corresponding pixel of the original image is detected.
- The brightness of the pixel is calculated.
- Based on the brightness, an ASCII character is selected from the given set (
asciiChars
).
- Drawing of characters: for each cell, the corresponding ASCII character is drawn.
- Image Refresh: the process is repeated for each new frame from the camera, creating a live ASCII video effect.
Read more about this project ➡️ Medium link
Here's an example of a peacock zoomed in at two levels to show the ASCII characters
The brightness of a pixel is calculated using the formula: 0.299_R + 0.587_G + 0.114B
double _calculateBrightness(Color pixel) {
return (0.299 * pixel.red + 0.587 * pixel.green + 0.114 * pixel.blue) / 255;
}
It should be said here that the size of your grid may vary by platform and device, so I’ve taken these settings out for customisation.
It's up to you to customize it: choose the characters you want to use and the size of the grid. On my android emulator I managed to achieve the desired effect with the following settings. You may have to play around with the settings for your device yourself. For web and iOS everything works fine (but you can of course increase the grid size for detail).
void main() {
const String asciiString = ".,_;^+*LTt1jZkAdGgDRNW@";
final List<String> asciiChars = asciiString.split('');
const Map<String, Map<String, double>> scaleParams = {
'web': {'scaleX': 160, 'scaleY': 120},
'ios': {'scaleX': 160, 'scaleY': 120},
'android': {'scaleX': 750, 'scaleY': 550},
};
runApp(
MaterialApp(
debugShowCheckedModeBanner: false,
home: CameraApp(
asciiChars: asciiChars,
scaleParams: scaleParams,
isColorMode: true, // color ASCII mode
),
),
);
}
By the way, you can also try other symbols like ⬇️
const String asciiString = "░▒▓█▓▒░";
If you'd like to improve the project, I'd be only too happy ʘ‿ʘ