0

So I have this problem where I'm receiving a webp,base64 image format from an api, The image does not show in ios devices but it appears in Android. So is there a solution for those who use expo and want to display webp images on ios? And I can take another solution if it works in php since that is what I'm using as a backend.

an example of the returned string of the image

https://i.stack.imgur.com/k1yHv.png

nix_
  • 9
  • 2
  • 8

1 Answers1

0

Normally webp images are not compatible with Safari. You can check the compatibility for webp here.

What you would need to do is maybe use a service that converts the image to a working format, be it jpeg or png and use a <picture> tag. This is just an example of how to use the tag.

<picture>
    <source srcset="images/logo@1x.webp" type="image/webp">
    <source srcset="images/logo@1x.png" type="image/png">
    <img src="images/logo@1x.png" alt="Logo">
</picture>

UPDATE

The above example was just to show you how to use the picture tag with different types of images.

As for the base64 images you could do something like this:

<picture>
    <source srcset="" type="image/webp">
    <source srcset="" type="image/jpeg">
    <img src="">
</picture>

Another option could be to use Modernizr to detect if the client's browser can use webp. You can check and build a Modernizr specifically for webp detection. Check it here.

What you would need to do if you have control over how the images are created/uploaded is to have a jpg/png and a webp version, and just use the corresponding versions as necessary. You do need to have both, because as I said before webp is still not compatible with every browser.

If you run the snippet you'll see that if you try to download the image it will use the webp version. If you open it from Safari it would download the jpg version.

UPDATE 2: Image conversion

As for the image conversion, what you could do is either make an image generating function that receives a webp image as a parameter and returns a jpg image.

Since you receive the image in a base64 format, you could use this topic to save the image on your server, but in a .webp format in your case. Afterwards you could use the imagecreatefromwebp() function to create a new image. Check the example at the end of that page. It converts a webp image to a jpeg.

From what I see you could do something like:

  1. Get your API call that contains information on the image.
  2. Check if your image exists on your server (the ideal is to create a specific folder and use the same image name).
  3. If it exists, you return the path to the image.
  4. If it doesn't exist, you create a .webp file from the base64 data. Then you convert it to a .jpg or a .png file depending on your needs.
  5. You use the local image. That might also speed up your calls.
Mihail Minkov
  • 2,463
  • 2
  • 24
  • 41
  • Can you please check the picture that I just added to the post? the syntax you used as a source looks different from what I received – nix_ Feb 10 '20 at 18:59
  • Yeah this looks more relatable to my problem, but I'm wondering how did you do the converting from webp to png and jpeg? And I'm using react native so I do not have the picture tag. – nix_ Feb 11 '20 at 18:54
  • Oh, well you'd have to do the conversion probably server-side. What are you building? Also, does the API handle an image format option? – Mihail Minkov Feb 12 '20 at 00:34
  • I'm using php as server-side scripting, and the only format that I can get from the API(serpapi) is webp. – nix_ Feb 12 '20 at 04:02
  • @NjoodAdel I added some more info on how it could work. – Mihail Minkov Feb 12 '20 at 18:17