An ASCIImage component for React Native
react-native-asciimage
Provides an component for React Native, powered by the excellent ASCIImage by @cparnot. It allows you to generate and insert images into your react-native app using ASCII art to describe the images (useful for small icons in UI elements).
Only iOS is currently supported.
Live Demo
Installation
- Run
npm install react-native-asciimage --save
- Open your project in XCode, right click on
Libraries
and clickAdd Files to "Your Project Name"
then choose theRNASCIImage.xcodeproj
. - Add
libRNASCIImage.a
toBuild Phases -> Link Binary With Libraries
. var ASCIImage = require('react-native-asciimage');
- Use the
<ASCIImage/>
element wherever you want to insert an image described by theascii
prop and optionalcolor
prop.
Usage
'use strict';
var React = require('react-native');
var ASCIImage = require('react-native-asciimage');
var { AppRegistry, View, Text } = React;
var myImage = [
'· · · 1 2 · · · · · ',
'· · · A # # · · · · ',
'· · · · # # # · · · ',
'· · · · · # # # · · ',
'· · · · · · 9 # 3 · ',
'· · · · · · 8 # 4 · ',
'· · · · · # # # · · ',
'· · · · # # # · · · ',
'· · · 7 # # · · · · ',
'· · · 6 5 · · · · · '
];
var App = React.createClass({
render: function() {
return (
<View>
<Text>
ASCIImage Example:
</Text>
<ASCIImage ascii={myImage} />
</View>
);
}
});
AppRegistry.registerComponent('App', () => App);
Result:
Alternate Usage
In some situations it's useful to work with an image URI rather than an Image
component (e.g., for use in TabBarIOS.Item
or NavigatorIOS
). To generate a (local) image URI, do the following:
...
var ASCIImage = require('react-native-asciimage');
var ASCIImageWriter = ASCIImage.Writer;
ASCIImageWriter.createImageFromASCII(myImage, '#ffffff', 40, function(imageURI) {
// Use the imageURI wherever it's needed
console.log(imageURI);
});
This will create an image saved in your application's Caches
directory for the specified color (example: #ffffff
) and width (example: 40
). It will automatically generate standard, @2x, and @3x sizes of the image, and will use cached images when they exist.
For advanced options (which would normally be passed in via the contextOptions
prop), you can use the expanded form:
var options = [
{ fillColor: "rgba(0, 0, 0, 0)", lineWidth: 5 }, // First shape
{ fillColor: "#0000ff" } // Second shape
];
ASCIImageWriter.createImageFromASCIIWithOptions(myImage, '#ffffff', 40, options, function(imageURI) {
console.log(imageURI);
}
Props
The following props are used:
ascii
(Array) REQUIRED - an array of strings representing rows of the image (see the ASCIImage documention for details)color
(String) the color value to use for the foreground, e.g.#0000FF
orrgba(0, 255, 0, 0.5)
. Default:#000000
contextOptions
(Array) Array of options for advanced control over the drawing of each shape. Array indices correspond to theASCIIContextShapeIndex
for each shape passed to the underlyingcontextHandler
block. Array values should be plain JavaScript objects with any of the following keys:fillColor
,strokeColor
,lineWidth
,shouldClose
, orshouldAntialias
.