| |
HCL
Registered: Feb 2003 Posts: 728 |
Screen limits
Once when i got myself a C= monitor, I made some tests to see what the actual limits were. Keeping in mind all the bugs i left in Royal Arte, after this i would never have to leave any visual bugs because of not seing them.
But now in EMU-age, the same horrible bugs appear again in many demos. Vice only shows 272 x 384 pixels, and people appearantly start to think that's the way to go. And it suxx big time!
So when i found my old screen tests yesterday, i thought maybe i should put this up here. I also had some info about sprite-limits in the borders. Let's get started.
Screen limits
-------------
Vertically:
First visible line: 8 (d012 = 8)
Last visible line: 12b (d012 = 2b)
That makes 292 visible lines totally.
Transfered to sprite positions we get..
spt-pos 12a: one line visible in lower border.
spt-pos 12b: one line visible in upper border.
Horizontally:
Left border: 48 visible pixels (6 chars).
Right border: 36 visible pixels (4.5 chars).
That makes 404 pixels, right.
Sprite bugs in left border:
All sprites invisible at positions 1f8-1ff.
spt7 invisible at pos <= 1ce.
spt8 invisivle at pos <= 1ee.
Sprite bugs in right border:
spt1 stretch bug at pos >= 14b.
spt2 stretch bug at pos >= 15b.
Bug above first line at pos => 163: spt 3,4,5.
Bug on last line at pos => 164: spt 3,4,5.
Ok. I think that's all. Does anyone have other specs? Please don't post if you have a lowsy TV-set, they always sukk. Did i get those sprite-bugs correctly? Sounds totally wierd :). And finally: DON'T RELEASE before you checked your demo against this spec >:E. |
|
... 103 posts hidden. Click here to view all posts.... |
| |
Krill
Registered: Apr 2002 Posts: 2981 |
MRT: I don't quite get your question. Are you mixing up something? |
| |
MRT Account closed
Registered: Sep 2005 Posts: 149 |
Yup.. :)
I was opening up the upper/lower borders in hires mode, but the column (or last char, etc.) trick didn't work there.
edit:
And it did work when I put the image in multicolor bitmap mode. Hence my mixup... :)
At least not on itself... I found out that I had to clear the last byte of the charsetbank! Even though I was using hires bitmap.
And I cleared the last byte of the VIC bank ofcourse...
The combination of those three seem to work and the lack of one of those seem to mask the background color...
But I don't understand it realy. I just filled up the vic bank with values to see what changed. Then later on I pinpointed the actual value that masked the borders. After changing that to $00 it works just fine... :-S
Oh for the record... I've tested this only on Vice and CCS.
|
| |
Monte Carlos
Registered: Jun 2004 Posts: 364 |
When i wrote this, i referred to upper/lower border, if i remember correctly.
In standart hires mode used without any tricks, $d021 register
is not of any use.
i think, it was due to some coding for "trip 2 nepa(l)" i wanted to show a hires picture with a background other than black. i wanted to open the upper/lower border too, for some reason. i set d021 to the background color of the hires picture and thoght, that it will be displayed on the upper/lower borders, too.
this guess was wrong, so i had to switch to multicolor mode in line 247 or so to display the borders in the correct color an switch back to hires mode in line 50.
this was not due to $ff in $xfff.
with the sideborders its kinda different, because as was told the color of zero pixels of the rightmost char is expanded into the sideborder.
anyway d021 doesnt play a role here, too.
|
| |
MRT Account closed
Registered: Sep 2005 Posts: 149 |
True, but...
What I ment was also for the upper/lower border. And I did a workaround by just turning off bitmap mode on line 247 and turn it back on on 50... :-)
BUT, what I was trying to say is that you could do without that workaround by (as you say it so nicely) putting some values on some addresses. :-D
Which can come in very handy when you don't have free rastertime around line 50.
The downside however, is that you need to have a blank (read: $00) value in your bitmap image (bitmap start + $7ff)
|
| |
Krill
Registered: Apr 2002 Posts: 2981 |
Ok, so i just patched VICE to display as much border as i want. I am planning to submit this fix to the source, so it will be in in one of the future versions. But, what are the real border sizes now?
With my 1084s, PAL display starts at line $0d, but only after some chars in the middle of the screen (the beginning of the line is black), and ends at line $012b inclusive.
What are your measurements? |
| |
Graham Account closed
Registered: Dec 2002 Posts: 990 |
1084S-D1, C64C:
$008-$12B
But the 1084S-D1 is a fucked up model anyway which is non-standard in many ways. For example, it cannot do real interlace, but it CAN do refresh rates like 200 Hz, 500 Hz etc. (Good for VDC programming, hehe) |
| |
JackAsser
Registered: Jun 2002 Posts: 2014 |
@Krill: I'll check my three 1084 using both old and new VIC-chip someday soon, however, is it possible to make the values adjustable in runtime or is it tons of static defines? |
| |
Krill
Registered: Apr 2002 Posts: 2981 |
Jackasser: Should now be easy to change at run-time, but is it that sensible a thing to do? :) |
| |
enthusi
Registered: May 2004 Posts: 677 |
such an option will probably make 90% of border-scrollers impossible to read on the real thing in future productions.
Forgive my whining, I just don't wanna have "hidden part: watch with vice". |
| |
JackAsser
Registered: Jun 2002 Posts: 2014 |
Quote: such an option will probably make 90% of border-scrollers impossible to read on the real thing in future productions.
Forgive my whining, I just don't wanna have "hidden part: watch with vice".
@krill, enthusi: On a real setup you can use the dials on your 1084s to adjust amount of visible gfx. I see no reason why this behaviour and usage shouldn't be emulated with VICE. :D Perferably using USB-dials to do the changes if I may feature creap a bit. ;)
|
Previous - 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 - Next |