Error Loading Local PNG for drawImage [help] #262
Replies: 5 comments 2 replies
-
the same problem |
Beta Was this translation helpful? Give feedback.
-
Has anyone found a work around for this? I'm trying to |
Beta Was this translation helpful? Give feedback.
-
@chixor @xwg2015 , the workaround is to have your image already be data uri... for example... However, if you turn it into data uri and put it into a variable, you can use that and everything works fine! // Data Uri |
Beta Was this translation helpful? Give feedback.
-
import React from 'react';
import {Image, SafeAreaView, Text} from 'react-native';
import Canvas, {Image as CanvasImage} from 'react-native-canvas';
const App = () => {
const iggle =
'';
// Pesudo CSS
const safeViewStyle = {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
};
const canvasStyle = {backgroundColor: 'white', width: 320, height: 320};
// Game Canvas
const gameCanvas = canvas => {
canvas.width = 320;
canvas.height = 320;
const ctx = canvas.getContext('2d');
ctx.clearRect(0, 0, 400, 400);
for (let i = 0; i < 4; i++) {
ctx.fillStyle = 'black';
ctx.fillRect(i * 80, i * 80, 80, 80);
}
};
const imageRect = canvas => {
canvas.width = 320;
canvas.height = 320;
const ctx = canvas.getContext('2d');
const image = new CanvasImage(canvas);
// image.src = require('./src/img/iggle.png');
image.src = iggle;
image.addEventListener('load', async () => {
console.log('nice');
return await ctx.drawImage(image, 0, 0, 16, 16, 80, 80, 80, 80);
});
};
return (
<SafeAreaView style={safeViewStyle}>
<Text>Now the React Native Canvas works great!</Text>
<Image source={require('./src/img/iggle.png')} />
<Canvas style={canvasStyle} ref={gameCanvas} />
<Canvas style={canvasStyle} ref={imageRect} />
</SafeAreaView>
);
};
export default App; |
Beta Was this translation helpful? Give feedback.
-
Question: How to read a "file://" local image in react-native-canvas? |
Beta Was this translation helpful? Give feedback.
-
I am trying to get a basic example working. This currently works using Expo's development server, but breaks when I attempt to build the iOS app to an iPad (I am using the Expo Bare Workflow).
The canvas allows me to draw simple shapes, so I know the canvas loads properly. I also tried calling
drawImage
on a remote url to ensure that worked.However, when I try to load a local image the
error
event is fired.The error callback seems to simply receive the entire Canvas object as a parameter. Is there a specific property within that object that can provide more details on the error? Right now I can't determine what's wrong just that something has gone wrong
Does anyone have experience loading local images with Expo if it is an error specific to this?
More context for what I have tried:
originWhitelist={["file://"]}
.Image.resolveAssetSource
Asset.fromModule
"/"
load
load
event.Please let me know if any more details would be useful, or if I'm simply missing something silly.
Thanks in advance!
Versions
^40.0.1
~0.4.1
^0.1.37
Beta Was this translation helpful? Give feedback.
All reactions