Author Topic: Writing picture data and "u" symbol  (Read 3711 times)

0 Members and 1 Guest are viewing this topic.

Offline boathouse2112

  • LV2 Member (Next: 40)
  • **
  • Posts: 23
  • Rating: +0/-0
    • View Profile
Writing picture data and "u" symbol
« on: September 06, 2012, 08:56:20 pm »
Ok. I know you can save pictures as vars, but is there a way to get the info for the picture so it can be used during the program like sprites. That way you don't have to worry about a var being overwritten. Also, at the beginning of sprites there's a u-symbol. I can't figure out how to access that on my calc. Any help?

Offline boathouse2112

  • LV2 Member (Next: 40)
  • **
  • Posts: 23
  • Rating: +0/-0
    • View Profile
Re: Writing picture data and "u" symbol
« Reply #1 on: September 06, 2012, 09:07:22 pm »
Sorry. Picked the wrong subforum.

Offline cooliojazz

  • Support Staff
  • LV7 Elite (Next: 700)
  • *******
  • Posts: 619
  • Rating: +66/-9
  • I omnoms on your soul
    • View Profile
    • Unreal Phantasies
Re: Writing picture data and "u" symbol
« Reply #2 on: September 06, 2012, 09:17:15 pm »
Okay, so since this is in the Axe subforum, I'm going to assume you are talking about Axe even though the way you discuss the concepts it sounds like Basic.  Yes you can include pictures, try adding "[Pic1]->GDB1" and it will import all the data from Pic1 into the program when you compile it, as long as Pic1 exists, then GDB1 will point to it.  I don't know what "overwriting variables" you talking about, but if you wanted to clarify, maybe I can help.  And about sprites... I don't know how you are trying to define sprites, but typically you write something like "[001122334455667788]->Pic1001", I don't know where you are seeing this funky u (which i would guess you are talking about [2ND]+[7])  Hope this helps! =)

EDIT: =( Okay, why did the necro warning not yell at me D=  So where did you mean to post it then?
EDIT2: So it is axe, you just put it in the wrong axe subforum? Confusion! =P Haha, w/e
« Last Edit: September 06, 2012, 09:20:15 pm by cooliojazz »
Spoiler For Random signess:
You can not beat my skills.
Trust me.
So don't even try.
And remember never to trust someone who says, "Trust me."

TI File Editor Progress: Remade in java like a boss. 50% we'll call it? IDK =P
Java Libraries: JIRC - 90% JTIF - 5%
TI Projects: Unreal Notator - -5000%
Nomcraft, a Bukkit mod
Some of the music I write can be found here | The Rest Should Be Here (Bandcamp)

Offline boathouse2112

  • LV2 Member (Next: 40)
  • **
  • Posts: 23
  • Rating: +0/-0
    • View Profile
Re: Writing picture data and "u" symbol
« Reply #3 on: September 06, 2012, 09:26:08 pm »
Ok. Forget the u. It was in a tut but works ok without. Correct me if i'm wrong, but if you store a variable in a program, (pic1>a) it will take whatever pic 1 is AT THE TIME OF USE and save it in a. I'm trying to find a way to make it work like sprites, where you put the hexcode in the program and assign it a variable ([132434HABC345]>a).
I'm a complete axe noob and don't know how to do something like that.

Edit:
The reason I sound like i'm talking basic concepts is because most of the concepts I understand are from basic...
« Last Edit: September 06, 2012, 09:27:13 pm by boathouse2112 »

Offline cooliojazz

  • Support Staff
  • LV7 Elite (Next: 700)
  • *******
  • Posts: 619
  • Rating: +66/-9
  • I omnoms on your soul
    • View Profile
    • Unreal Phantasies
Re: Writing picture data and "u" symbol
« Reply #4 on: September 06, 2012, 10:39:55 pm »
Okay, because you're coming from Basic, I'm going to make sure you understand a concept then.  When you do something like [01]->A, you are making the compiler put the number 01 somewhere at the end of your program, then giving you a POINTER to that, or a number that tells you where that number is stored.  The "variable" doesn't actually hold the data itself, it just tells you where to go to find the data.  So storing the picture is exactly the same as storing a sprite except for two things, the length of the actual data stored, and the format of the data stored.  If you import a picture, (And yes, it is whatever it is when you compile it, because it literally copies the picture data into the code at the end of your program) it will be 768 (i think, somewhere around there =P) bytes, while sprites are 8.  Also, if you tried to just use an imported picture with the sprite command, it would be not what you would expect, as it would read the first 8 bytes of data (each 8 pixels is stored in a single byte, one pixel per bit) which would be the first 64 pixels in the first row, and write it as an 8x8 sprite.  You can use [picvarr] to import it as a spritemap, which is probably what you want, which will actually make sure the data is imported in the correct format for being used with the Pt- commands.  Just remember if you use that, each sprite is 8 bytes long.  Back to pointers, remember how they only tell you where the data is, not what it is?  You can do math with pointers too, for some very useful results. Say you do [010203]->A, then ask it what {A} (The value stored at A) is.  What would it tell you? 01, because A points to the start of that data!  Now what if you did {A+1}, what would it give you?  Now it's 02 instead, because that is the data in the byte after 01!  {A+2}? 03!  So now think of when you import that picture into your program as sprites.  It will import them in by rows, each row having 12 bytes (96/8=12) and there will be 8 rows (64/8=8).  There aren't any actual "rows" of course, because remember, the data is all layed out linearly, like [row1][row2][etc.], but knowing everything we know, it's easy to find a specific sprite!  If Pic1 is a pointer to our data (Also, the pic vars really arent variables, but that's a whole 'nother story!) we could pass Pic1 to a Pt- routine to have it draw the first sprite for us.  Cool, but what about the other ones?  So, remembering that each sprite is 8 bytes long, we can simply give it an 8 byte offset to the data to have it start reading there instead! If we give a Pt- routine Pic1+8 instead, it will draw the second sprite!  In fact, we can generalize this, and so every sprite can be accessed at {S-1*8+Pic1} (Don't forget Axe's fun order of operations; all left to right!) where S is the sprite number.  Okay, so that should probably tide you over for a bit, ask if you need more ;P

Sorry if this was all a bit gratuitous or pedestrian for you, you said complete nub, so I assumed very minimal knowledge =P  Hope this helps!
Spoiler For Random signess:
You can not beat my skills.
Trust me.
So don't even try.
And remember never to trust someone who says, "Trust me."

TI File Editor Progress: Remade in java like a boss. 50% we'll call it? IDK =P
Java Libraries: JIRC - 90% JTIF - 5%
TI Projects: Unreal Notator - -5000%
Nomcraft, a Bukkit mod
Some of the music I write can be found here | The Rest Should Be Here (Bandcamp)