Why does Imagemagick produce strange results when converting to WEBP format? - imagemagick

I was experimenting with JPEG2000 and WEBP through Imagemagick. They were both giving me much better compression levels than I had gotten from JPEG in GIMP, with WEBP doing better than JPEG2000. But when I changed the input image from a JPEG to a PNG, WEBP suddenly started creating output files that were even larger than the input. JPEG2000 showed no significant change. I tried to add options like -format webp and -define webp:lossless=fase, but they didn't help.
Also, my file manager and identify both insist that the resulting file is a PNG and not a WEBP. I later checked and found that the files converted from JPEG were also considered JPEGs, even though they were smaller than the fine-tuned JPEG2000s.
All images had the same quality level of 85. Imagemagick supposedly supports WEBP natively, and I also have libwebp installed. JPEG2000 is being handled by libJasPer.
What is going on?

Related

pngData() file save is lossy or lossless

We are saving image as png file in swift as below
pngData().write(fileURL,atomic)
The file saved is lossy or lossless ?
I checked for any tools online but did not find answers.
PNG is lossless, check the official documentation image above.

Looking for a way to create compressed png files in lua/luajit

I'm writing a mod for a game that uses lua/luajit as a scripting language and I would like to create a png file dynamically using lua. I've been googling for a png library/module but could only find ones that merely read pngs (like https://github.com/Didericis/png-lua or https://luapower.com/libpng), or create uncompressed pngs: https://github.com/wyozi/lua-pngencoder
On my search I have stumbled upon libpng and thought, maybe I could simply load that dll using ffi and use the functions that way. But the problem is that is waaaay too complicated for me, since I'm not familiar with C and furthermore libpng seems to be a huuuuuge complicated library.
So, is there any simple way (module/library) that I missed and didn't find on google?
I just need very simple functionality, create a png, set the pixels, save it as a compressed png file.

Extract bezier paths from a png

I want to extract bezier paths from a png like this.
sample image
potrace doesn't support reading PNG files natively. You'd need to convert PNG images to another supported format first. http://potrace.sourceforge.net/faq.html#formats
However potrace is licensed under the GPL so while it does compile for iOS you may not want to use it as part of an app. Is it possible to compile potrace for iOS? There is a non-GPL version of potrace available, but it isn't free.
Depending on the complexity of the PNG images you want to convert, you may get less than ideal results anyway.
If you update your question with more detail about what you are trying to achieve it might be possible to give a better answer.

How to convert jpg or png to svg in iOS?

I like to convert an .jpg or .png file to an .svg format that can be displayed in UIImageView. Is there a way to do this in Objective-C?
You shouldn't use SVG images in Xcode:
it is recommended that you use PNG or JPEG files for most images in your app. Image objects are optimized for reading and displaying both formats, and those formats offer better performance than most other image formats. Because the PNG format is lossless, it is especially recommended for the images you use in your app’s interface.
Also, there's an SVGKit that according to many devs is buggy so use it at your own risk.
SVG is an XML-based vector and in Xcode you can also use vectors but using a PDF format and follow this tutorial.
In a nutshell:
Generate PDFs With the #1x Asset (During compile time it will generate #2 and #3)
Set the Scale Factors to Single Vector:
Drag and Drop Your PDF Into the All, Universal Section
Refer to Your Image by Its Name, Like for any PNG File
[UIImage imageNamed:#”Home”]
Also, stackoverflow (perhaps) related answer
To convert PNG to SVG (Which is a very sensible and valid thing to do) you need an app or library called a "tracer". It will trace the outlines of shapes, gradients, etc and convert them into vector representations.
For simple cases, this is easy for a computer to do; for complex cases (e.g. gradients), this is a very hard AI / Computer-Vision problem and you'd need to spend $$$ on high-end coding solutions and/or find PhD-level research that solves the problem!
A free tracer that does a very good job is built-in to Inkscape (open-source) - google "inkscape trace" for tutorials on how to use it, and to generate a .svg file that you can use. This is a manual process.
To use this in-app, you need to find a tracing library for iOS. The libraries that Inkscape uses are all open-source, so you could try converting them to iOS - they're written in C, so it could be quite easy.

Decompress PNG directly to disk

I have a large PNG that I want uncompressed to a file, but I don't have the memory capacity on the device to expand the PNG in memory, then to a file.
Is there a native iOS method to uncompress a PNG for each scan line? Alternatives?
Libpng - Reading image data - http://www.libpng.org/pub/png/libpng-1.2.5-manual.html#section-3.8
For non-interlaced PNGs
png_read_rows(png_ptr, row_pointers, NULL, number_of_rows);
As and idea how to start:
Take a look how is doing Java the png decompressing algorithm. Java should have open-source those files. Maybe has the iOS too idk. Just get the uncompress algorithm idea. It should be around 1k-5k lines of code.
When you know how to do it, than implement at iOS but read a chunk of file and than export to a file, read another chunk and process and export it. I know it is easy to say and at least theoretically it is working. Maybe is public in some site. Libpng can be a good starting point.
Png is a looseness compression like zip. There as I have remember runtime is built a data table. Those table depends how big is, maybe need to be swapped to to disk, which will makes longer the decompression process.
Good luck!

Resources