Author Topic: Feature Request: More Colors for SCREEN 0  (Read 5366 times)

0 Members and 1 Guest are viewing this topic.

Offline manstersoft

  • Newbie
  • Posts: 22
    • View Profile
    • My Games
Feature Request: More Colors for SCREEN 0
« on: August 13, 2020, 11:17:00 pm »
Edit: This post was a bug report regarding the SCREEN() Function, but as SMcNeil pointed out...
SCREEN 0 stores your ASCII character in memory, so it can always retrieve that value for you.  No other screen does this.

A graphical screen draws GRAPHICS onto the screen and has to compare pixel-by-pixel to guess at what the character is in any given space.  It can't tell you the difference in CHR$(0), CHR$(32), or CHR$(255).  If you draw a line above a period, it might read that as a colon or semi-colon.

I've dabbled in a few other iterations of BASIC, and the reason I never wanted to switch was because they all lacked a SCREEN() Function. It's one of the wonderfully unique aspects of qbasic/qb64. But...

I would argue that the worst limitation of qbasic/qb64's SCREEN 0 is being limited to 16 Colors (attributes) and worst of all 8 background colors (attributes). This limitation is something I've struggled with in my ASCII games for a long time. Would it be possible to have a way to up that limitation? 64 seems like a logical number (DAC). 256 would be better.

SCREEN 0 can already successfully load custom fonts (and scale them), and can use the SCREEN() function. Removing the COLOR limitations would make it perfect in my book.

My old post that details the issues with using SCREEN() in graphic modes is below...
Quote
Issue 1: In modes other than 0; using SCREEN() to find an ASCII character on a background other than COLOR ,0 results in a solid block (cc 219).
Code: QB64: [Select]
  1. SCREEN _NEWIMAGE(640, 480, 256): _FONT 8
  2. COLOR 5, 1
  3. PRINT "Hello World!"
  4. PRINT SCREEN(1, 6); SCREEN(1, 7)
  5. COLOR 5, 0
  6. PRINT "Hello World!"
  7. PRINT SCREEN(3, 6); SCREEN(3, 7)

Issue 2: In modes other than 0; Using SCREEN() after loading a custom font triggers an illegal function call.
Code: QB64: [Select]
  1. SCREEN _NEWIMAGE(640, 480, 256)
  2. F = _LOADFONT("cyberbit.ttf", 32, "monospace") 'replacing with F = 8 works fine
  3. PRINT "Hello World!"

I tested 256, 32, and SCREEN 12. With both FONT 8 and FONT 16
« Last Edit: August 16, 2020, 01:05:44 pm by manstersoft »

Offline Cobalt

  • QB64 Developer
  • Forum Resident
  • Posts: 878
  • At 60 I become highly radioactive!
    • View Profile
Re: Bug: SCREEN() Function issues
« Reply #1 on: August 14, 2020, 12:40:57 am »
as per wiki,
"The code value returned is the ASCII code from 0 to 255."

 so it is meant to work with the BIOS font. not a loaded TTF
and I'm guessing its meant to work with the 8x16 form not the 8x8 form, but not sure there.

just FYI.
Granted after becoming radioactive I only have a half-life!

Offline manstersoft

  • Newbie
  • Posts: 22
    • View Profile
    • My Games
Re: Bug: SCREEN() Function issues
« Reply #2 on: August 14, 2020, 01:04:15 pm »
as per wiki,
"The code value returned is the ASCII code from 0 to 255."

 so it is meant to work with the BIOS font. not a loaded TTF
As I said, when using SCREEN 0 and a custom font, Issue 2 doesn't happen.
Custom fonts do read ASCII. Otherwise the _MAPUNICODE statement would be useless.

and I'm guessing its meant to work with the 8x16 form not the 8x8 form, but not sure there.
I tested everything with both FONT 8 and FONT 16. Both bring up the issues.
« Last Edit: August 14, 2020, 01:14:47 pm by manstersoft »

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: Bug: SCREEN() Function issues
« Reply #3 on: August 14, 2020, 02:34:57 pm »
One thing to remember guys:  SCREEN 0 stores your ASCII character in memory, so it can always retrieve that value for you.  No other screen does this.

A graphical screen draws GRAPHICS onto the screen and has to compare pixel-by-pixel to guess at what the character is in any given space.  It can't tell you the difference in CHR$(0), CHR$(32), or CHR$(255).  If you draw a line above a period, it might read that as a colon or semi-colon.
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

Offline manstersoft

  • Newbie
  • Posts: 22
    • View Profile
    • My Games
Re: Bug: SCREEN() Function issues
« Reply #4 on: August 14, 2020, 02:40:38 pm »
One thing to remember guys:  SCREEN 0 stores your ASCII character in memory, so it can always retrieve that value for you.  No other screen does this.

A graphical screen draws GRAPHICS onto the screen and has to compare pixel-by-pixel to guess at what the character is in any given space.  It can't tell you the difference in CHR$(0), CHR$(32), or CHR$(255).  If you draw a line above a period, it might read that as a colon or semi-colon.
Dang, I feared that might be the case.
In that case it's less of a bug and more of a miracle that the graphical screens can use SCREEN() at all.
I've edited my post.

To be honest, all I really want is a Text mode with more than 16 fg / 8 bg colors. That's the only reason I use SCREEN _NEWIMAGE(x,y,256) to begin with. The limitation seems like a needless relic from the qbasic days.
« Last Edit: August 14, 2020, 02:53:56 pm by manstersoft »

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: Feature Request: More Colors for SCREEN 0
« Reply #5 on: August 14, 2020, 04:21:49 pm »
One easy trick is to use 2 screens and work with both at the same time.

DisplayScreen = _NEWIMAGE(X, Y, 256)
CharacterScreen =_NEWIMAGE(R, C, 0)
SCREEN DisplayScreen
PrintBoth "Foo"

SUB PrintBoth(text$)
  _DEST CharacterScreen
  PRINT text$
  _DEST DisplayScreen
  PRINT text$
END SUB

Now, you can use SCREEN with the text screen (CharacterScreen), and retrieve your characters properly.
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

Offline manstersoft

  • Newbie
  • Posts: 22
    • View Profile
    • My Games
Re: Feature Request: More Colors for SCREEN 0
« Reply #6 on: August 14, 2020, 05:17:19 pm »
One easy trick is to use 2 screens and work with both at the same time.

Code: QB64: [Select]
  1. DisplayScreen = _NEWIMAGE(640, 400, 256)
  2. CharacterScreen = _NEWIMAGE(80, 50, 0)
  3. SCREEN DisplayScreen: _FONT 8
  4. PrintBoth "Foo"
  5.  
  6.  
  7. SUB PrintBoth (text$)
  8.     _DEST CharacterScreen
  9.     PRINT text$
  10.     _DEST DisplayScreen
  11.     PRINT text$
  12.  

Now, you can use SCREEN with the text screen (CharacterScreen), and retrieve your characters properly.
Interesting. I updated with my own variables.

_DEST is new to me; is it like a more flexible way of page flipping?
Also, on the code above, why is "Foo" printed twice, even though we're viewing SCREEN DisplayScreen? Maybe I'm missing something.
« Last Edit: August 14, 2020, 05:29:29 pm by manstersoft »

FellippeHeitor

  • Guest
Re: Feature Request: More Colors for SCREEN 0
« Reply #7 on: August 14, 2020, 05:39:55 pm »
Add DIM SHARED DisplayScreen  AS LONG, CharacterScreen AS LONG to the top.

Offline manstersoft

  • Newbie
  • Posts: 22
    • View Profile
    • My Games
Re: Feature Request: More Colors for SCREEN 0
« Reply #8 on: August 14, 2020, 06:04:34 pm »
Oh, haha. I should have noticed that. Alright, I'll mess with this in the following couple of days.
Thanks to you both.
I would of course prefer that SCREEN 0 gets more colors (or another text mode is added so as not to mess with blinking text compatibility). I don't know the feasibility of that addition though.

Offline Pete

  • Forum Resident
  • Posts: 2361
  • Cuz I sez so, varmint!
    • View Profile
Re: Feature Request: More Colors for SCREEN 0
« Reply #9 on: August 15, 2020, 11:22:04 pm »
I use PALETTE to squeeze out a little more color in my SCREEN 0 programs. Screen Zero, the only screen anyone really needs.

Pete
Want to learn how to write code on cave walls? https://www.tapatalk.com/groups/qbasic/qbasic-f1/

Offline manstersoft

  • Newbie
  • Posts: 22
    • View Profile
    • My Games
Re: Feature Request: More Colors for SCREEN 0
« Reply #10 on: August 16, 2020, 10:48:52 am »
I use PALETTE to squeeze out a little more color in my SCREEN 0 programs. Screen Zero, the only screen anyone really needs.

Pete
What I'm looking for is more attributes; More than 16 Colors on screen at the same time.

And really, 16 Colors is enough. But 8 background colors? Woof.

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: Feature Request: More Colors for SCREEN 0
« Reply #11 on: August 16, 2020, 12:18:34 pm »
What I'm looking for is more attributes; More than 16 Colors on screen at the same time.

And really, 16 Colors is enough. But 8 background colors? Woof.

If you turn off blinking, you can have 16 background colors.
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

FellippeHeitor

  • Guest
Re: Feature Request: More Colors for SCREEN 0
« Reply #12 on: August 16, 2020, 12:19:42 pm »
Indeed, with _BLINK OFF.

I don't know how they behave regarding PALETTE though. Uncharted territory there.

Offline manstersoft

  • Newbie
  • Posts: 22
    • View Profile
    • My Games
Re: Feature Request: More Colors for SCREEN 0
« Reply #13 on: August 16, 2020, 12:30:06 pm »
I saw that on the wiki, but I was unable to get it to work.
The blinking did stop, but for example COLOR ,9 is always COLOR ,1

FellippeHeitor

  • Guest
Re: Feature Request: More Colors for SCREEN 0
« Reply #14 on: August 16, 2020, 12:36:15 pm »
You must go beyond color 15 to get it to work, since high-intensity backgrounds take place of the blinking spots. Try COLOR 31, 9, for example.