Author Topic: Compressed image as DATA in own source code  (Read 4940 times)

0 Members and 1 Guest are viewing this topic.

Offline Petr

  • Forum Resident
  • Posts: 1720
  • The best code is the DNA of the hops.
    • View Profile
Compressed image as DATA in own source code
« on: December 21, 2019, 05:13:14 pm »
Hi.
I developed my own compression routine for simple images. It doesn't work for complex photos, but for simple pictures like the one in the attachment. On purpose. How to insert the attached image into the source code while preserving the size of the source code 19044 bytes (of course, it could be created using internal commands, but we are talking about inserting the photo into the source code).

Code: QB64: [Select]
  1. DATA 592,435: 'width, height
  2. DATA 2205,5,2205: 'UBOUNDy pro Popis, PoleBarev, PrepniBarvu, v tomto poradi je to dale zapsano
  3. '    PRINT PoleBarev(Load2)
  4.  
  5. FOR Load3 = 0 TO UPrepniBarvu
  6.     READ pb$
  7.     PrepniBarvu(Load3) = VAL("&H" + pb$)
  8.  
  9. RESTOREPIC width, height, popis(), PoleBarev(), PrepniBarvu()
  10.  
  11. SUB RESTOREPIC (sirka, vyska, popis() AS LONG, PoleBarev() AS _UNSIGNED LONG, PrepniBarvu() AS LONG)
  12.     SCREEN _NEWIMAGE(sirka, vyska, 32)
  13.     j = -1
  14.     MaximalniOffset = MAXSIZEOF(PrepniBarvu())
  15.     DIM i AS LONG
  16.     FOR h = 0 TO vyska - 1
  17.         FOR w = 0 TO sirka - 1
  18.             'vyhledat, jestli mam prepnout barvu
  19.  
  20.             IF i < MaximalniOffset THEN
  21.                 FOR T = OldT TO UBOUND(prepnibarvu)
  22.                     IF i = PrepniBarvu(T) THEN
  23.                         j = j + 1
  24.                         COLOR PoleBarev(popis(j))
  25.                         OldT = T
  26.                     END IF
  27.  
  28.                     IF PrepniBarvu(T) > i THEN EXIT FOR
  29.                 NEXT T
  30.             END IF
  31.  
  32.             PSET (w, h)
  33.             i = i + 1
  34.     NEXT w, h
  35.  
  36. FUNCTION MAXSIZEOF (a() AS LONG)
  37.     FOR t = LBOUND(a) TO UBOUND(a) - 1
  38.         IF MAXSIZEOF < a(t) THEN MAXSIZEOF = a(t) + 1
  39.     NEXT
  40.  

 
haus.bmp


Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: Compressed image as DATA in own source code
« Reply #1 on: December 21, 2019, 06:29:51 pm »
When we finally update to v1.4, QB64 will come with ZLIB compression routines included.  Then you’d be able to just do something like:

DIM m AS _MEM: m = _MEMIMAGE(imagehandle)
temp$ = SPACE$(m.SIZE)
_MEMGET m, m.OFFSET, temp$ ‘Put the image to a temp string

compressed$ = _DEFLATE(temp$) ‘compress it

uncompressed$ = _INFLATE(compressed$) ‘uncompress it
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

Offline Petr

  • Forum Resident
  • Posts: 1720
  • The best code is the DNA of the hops.
    • View Profile
Re: Compressed image as DATA in own source code
« Reply #2 on: December 21, 2019, 06:53:00 pm »
Hi Steve.
I'll take a look at this feature. I realized that further compression could be achieved by expanding the set of letters. So to be more precise, let's give it the HEX$ command. It uses a maximum of F as the number 15. I'm thinking of a custom function that would use other letters to distinguish a value. The 16-bit HEX$ is an inspiration for me, but there is an obvious possibility of expansion. Writing number 15 would still be F, but number 16 would be G ... well I'll try to think about it again. The point is to use the full range, which is directly viewable in a text mode editor for this purpose.

And you're talking about it. Of course I was inspired by the GIF compression algorithm. As always, I did it in my own way, so as how I understand it.
« Last Edit: December 21, 2019, 06:56:33 pm by Petr »

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: Compressed image as DATA in own source code
« Reply #3 on: December 21, 2019, 07:05:53 pm »
A-Z is 26 letters
a-z is 26 more.
0-9 is 10 more.
Add 2 more characters you like (@#), that’d give you a total of 64 characters, which would be a nice expansion over 16-character hex$, and still a nice power of 2.  ;)
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

Offline AndyA

  • Newbie
  • Posts: 73
    • View Profile
Re: Compressed image as DATA in own source code
« Reply #4 on: December 22, 2019, 09:32:18 pm »
Hi guys,

It looks to me as if you are re-inventing Base64 encoding. It's supported by most browsers.

The main advantage over Hex is that Base64 is 66% smaller due to more bits are being used when encoding, as Steve mentioned. 6 bits vs. 4 bits.

Base64 is standardized (for the most part) and can be used to paste images or zip files in the browser search window. Correct mime-type must be specified. See: https://en.wikipedia.org/wiki/Base64
and also https://en.wikipedia.org/wiki/Data_URI_scheme


In this example the image is specified as a jpeg. To view the image, copy and paste the date into the browser search window.

Using Chrome:
1) Copy the data from the code box below.
2) Open Chrome and right click in the search window (where you type your question or URL)
3) From the pop-up menu, select "Past and go..."
4) A new tab shows up with the decoded image. You can right click on the image and save to disk.


Curly Fern IFS image: 100x75
Code: [Select]

I've already posted a few version of Base64 encoded files for:
Blitz Basic  https://socoder.net/?Snippet=33278
SDL Basic  http://sdlbasic.epizy.com/showthread.php?tid=398
JustBasic (link no longer available as old forum was closed)

Currently working on the QB64 version. Would like to create in an InForm GUI eventually.
« Last Edit: December 22, 2019, 11:39:53 pm by AndyA »

FellippeHeitor

  • Guest
Re: Compressed image as DATA in own source code
« Reply #5 on: December 22, 2019, 10:00:01 pm »
Would like to create in an InForm GUI eventually.

That'll be cool! Let me know if I can be of assistance.

Offline Petr

  • Forum Resident
  • Posts: 1720
  • The best code is the DNA of the hops.
    • View Profile
Re: Compressed image as DATA in own source code
« Reply #6 on: December 23, 2019, 03:46:21 am »
Hi, yes, I'm going to try something like that. Because I will try this for the first time, it is certain that I will come to a dead end several times. I will now only try this thing during the Christmas holidays. Thank you for links, AndyA, now i try to do it compatible. It is very helpfully for me.

Offline AndyA

  • Newbie
  • Posts: 73
    • View Profile
Re: Compressed image as DATA in own source code
« Reply #7 on: December 23, 2019, 08:25:02 am »
Hi Petr,

I will be posting QB64 code as soon as possible, probably this evening or tomorrow evening.

This will make it easier to add to your own programs, if desired.

But what this utility really needs is a GUI to allow end user to make output choices with a mouse click, instead of editing source code. Think InForm. Thanks Fellippe!

Offline Petr

  • Forum Resident
  • Posts: 1720
  • The best code is the DNA of the hops.
    • View Profile
Re: Compressed image as DATA in own source code
« Reply #8 on: December 23, 2019, 01:47:22 pm »
Hi AndyA,

I have studied BASE64 coding several times. It's basically a different compression than the one I used in the code above, but I've done my own BASE64 decoder (which only converts integer numbers up to 999999999 to BASE64 characters so far). I will also try to create BASE64 data compression itself, in parallel with you. It's an absolutely brilliant way I studied it that way. I like it very much.

Offline Petr

  • Forum Resident
  • Posts: 1720
  • The best code is the DNA of the hops.
    • View Profile
Re: Compressed image as DATA in own source code
« Reply #9 on: December 24, 2019, 08:05:44 am »
Hi AndyA, i do some experiments with this your link

Quote
Curly Fern IFS image: 100x75
Code: [Select]


in my program with this output: My program write jpg file correctly, jpg is visible using windows photo viewer, but QB64 can not load this image, because is uncompatible with _LOADIMAGE.

 
extracted image.jpg


And as me reply, please try
Code: [Select]

« Last Edit: December 24, 2019, 08:10:15 am by Petr »

Offline AndyA

  • Newbie
  • Posts: 73
    • View Profile
Re: Compressed image as DATA in own source code
« Reply #10 on: December 24, 2019, 06:37:55 pm »
I get the same error that you do.

Here is the QB64 code I used to test:
Code: QB64: [Select]
  1. SCREEN _NEWIMAGE(400, 300, 32)
  2.  
  3. 'This is the image I saved from Chrome using the posted data:image URI
  4. imgName$ = "CurlyFern_100x75_fromDATA_URI.jpg"
  5.  
  6. imgHandle& = _LOADIMAGE(imgName$, 32)
  7. PRINT imgHandle& '<--- not loading???
  8. _SOURCE imgHandle&
  9.  

I also tested in BlitzPlus Basic and MS Paint, and it worked.
Code: Text: [Select]
  1. Graphics 400,300,32,2
  2. SetBuffer BackBuffer()
  3.  
  4. img% = LoadImage("CurlyFern_100x75_fromDATA_URI.jpg")
  5.  
  6. DrawImage img%,150,112
  7. Flip
  8. WaitMouse()
  9.  
  10. End

So I tend to think that it may be an incomplete .JPG (from data:image URI) that the QB64 JPG image loader has trouble with, and the others (MS Photo Viewer, MS Paint, BlitzPlus Basic) can decode.

The reason I say incomplete is because, from the image you posted, it looks very slightly cropped at bottom compared to the original .JPG I used to make the Base64 encoding. This may be due to the manual process I used to strip the word DATA and the double quotes in MS WordPad from the QB64 encoded image output.

I'll do more testing after Christmas to try and determine the issue.
« Last Edit: December 24, 2019, 06:48:35 pm by AndyA »

Offline Petr

  • Forum Resident
  • Posts: 1720
  • The best code is the DNA of the hops.
    • View Profile
Re: Compressed image as DATA in own source code
« Reply #11 on: December 25, 2019, 04:23:43 am »
Just compare the size of the original file with the output size the image am sent here. And it is certainly enough after Christmas. And if the size is the same, it is a beautiful opportunity to try HEX editor from Eoredson :)