Skip to content

khlebobul/ascii_camera

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ascii_camera

Codacy Badge License: MIT

Flutter application, to create ASCII effect

SCR-20241017-odol

About this project

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.

Demo

demo

Table of Contents

Usage

To implement this project I used the camera package and ASCII characters. The project works as follows ⬇️

1_nB7Cx6VyqYLZlbAr9B79NQ
  • 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

example

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.

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 = "░▒▓█▓▒░";

Contributions

If you'd like to improve the project, I'd be only too happy ʘ‿ʘ