Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Importing Different Images into the Image Component by path, url or base64. #1204

Closed
Andersonfrfilho opened this issue Nov 28, 2019 · 8 comments

Comments

@Andersonfrfilho
Copy link

Question

Guys, since I am already having problems importing image I need to show different images in each mode, but when trying

<Image
   href={require(`../../../assets/images/questions/${imageName}.png`)}//eslint-disable-line
/>

an error is returned

Loading dependency graph, done.
error: bundling failed: src\components\OptionImage\index.js: src\components\OptionImage\index.js:Invalid call at line 39: require("../../../assets/images/questions/" + imageName + ".png")

trying

<Image
    href={require('../../../assets/images/questions/'+imageName+'.png')}
/>

an error is returned

Loading dependency graph, done.
error: bundling failed: src\components\OptionImage\index.js: src\components\OptionImage\index.js:Invalid call at line 38: require('../../../assets/images/questions/' + imageName + '.png')

using

          <Photo
            href={require('../../../assets/images/questions/default.png')}//eslint-disable-line
          />

works but gets static image I can't change

could anyone help thank you.

@msand
Copy link
Collaborator

msand commented Dec 9, 2019

Require each object into a variable, create a object with properties set to those values, then use a key to access the one you need with what ever logic you want:

const defaultImage = require('./cat.png');
const house = require('./house.png');
const car = require('./car.png');
const images = {
  house,
  car,
};
export const ValueDependantImage = ({ imageType, ...rest }) => (
  <Image href={images[imageType] || defaultImage} {...rest} />
);

@Andersonfrfilho
Copy link
Author

@msand, all good?, thank you for the answer, the app from the beginning was something more static, and eventually grew.
It is a question and answer quiz, so it will have various images, these being on base64, would there be any way to use this code, in your component? or would I have to convert a .png file with module react-native-fs and then use this path?

@Andersonfrfilho Andersonfrfilho changed the title Importing Different Images into the Image Component Importing Different Images into the Image Component by path, url or base64. Dec 10, 2019
@msand
Copy link
Collaborator

msand commented Dec 10, 2019

@Andersonfrfilho
Copy link
Author

Thanks again, @msand , I will apply this to my project, because I had to make a change with react-native's image component, I turn something bad in the code. Thanks a lot ^^.

@Andersonfrfilho
Copy link
Author

Andersonfrfilho commented Jan 10, 2020

@msand, I thank you for the return, but applying the tips you posted the problem does not solve, The example you provided does not solve the problem because I have to put an svg overlaying the image, this image comes from a base64 API Route, so I may or may not use the
react-native-svg component of

<Image />

? Does it support image in base64 mode?

in the example sent it uses react-native and view not solving the problem,
because you should use image of react-native-svg <Image /> component and not react-native because svg does not override react-native image.

Capturar
here is an image of the problem, i need to use the <image/> component of react-native-svg, which has transitions and that uses as url basex64.
Thanks.

@Andersonfrfilho
Copy link
Author

Andersonfrfilho commented Jan 10, 2020

I think this example would fit the problem better:
https://github.com/magicismight/react-native-svg-example/blob/5a972149f22e0464152d487e6aab015a368ba02a/examples/Image.js

class DataURI extends Component{
    static title = 'Data URI';

    render() {
        return <Svg
            height="100"
            width="100"
        >
            <Image
                x="5%"
                y="5%"
                width="90%"
                height="90%"
                href={{uri: ''}}
                opacity="0.6"
            />
        </Svg>;
    }
}

@msand
Copy link
Collaborator

msand commented Jan 10, 2020

base64 is supported yes. You fixed it?

@Andersonfrfilho
Copy link
Author

Andersonfrfilho commented Jan 10, 2020

@msand, thank you for your attention
yes , work with the example above:

I think this example would fit the problem better:
https://github.com/magicismight/react-native-svg-example/blob/5a972149f22e0464152d487e6aab015a368ba02a/examples/Image.js

class DataURI extends Component{
    static title = 'Data URI';

    render() {
        return <Svg
            height="100"
            width="100"
        >
            <Image
                x="5%"
                y="5%"
                width="90%"
                height="90%"
                href={{uri: ''}}
                opacity="0.6"
            />
        </Svg>;
    }
}

because the link you submitted does not use the

Sure :) You're welcome. You can give base64 as url like this:
https://github.com/magicismight/react-native-svg-example/blob/5a972149f22e0464152d487e6aab015a368ba02a/examples/Svg.js#L177-L182

<Image/> component react-native-svg, but reacts-native,
so it didn't solve the problem but with this other example it uses image for base64.
And using base64 eliminates the problem of transitions that are no longer the number of times this problem is specific
thanks again for the feedback

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants