mirror of
https://github.com/deater/dos33fsprogs.git
synced 2025-01-22 04:30:38 +00:00
193 lines
4.6 KiB
Plaintext
193 lines
4.6 KiB
Plaintext
VGI -- VMW Retro Vector Graphics Interface
|
|
|
|
This was designed mostly as a proof-of-concept to drawing some Myst
|
|
scenes. Might not work well for general graphics.
|
|
|
|
The Apple II Hi-res screen is 280x192 and 6 colors with lots of limitations
|
|
that are a bit complex to get into here. Some of the limitations in the
|
|
interface here are working around Apple II issues.
|
|
|
|
|
|
Apple II Hi-res Colors:
|
|
~~~~~~~~~~~~~~~~~~~~~~~
|
|
0 = black (for purple/green)
|
|
1 = green
|
|
2 = purple
|
|
3 = white (for purple/green)
|
|
4 = black (for blue/orange)
|
|
5 = orange
|
|
6 = blue
|
|
7 = white (for blue/orange)
|
|
|
|
|
|
Note Apple II uses NTSC artifact colors, so weird things happens when
|
|
you try to put colors next to each other:
|
|
|
|
+ Colors need to be two pixels wide, if you draw single width
|
|
they may not appear depending on even/odd column
|
|
+ White lines drawn single width will be colored instead
|
|
+ Two colors of same group next to each other will have white or black
|
|
border between
|
|
+ Two colors of different group next to each other will have odd effects
|
|
as can only change group every 3.5 pixels.
|
|
|
|
|
|
The VGI Commands
|
|
~~~~~~~~~~~~~~~~
|
|
|
|
===================
|
|
VGI Clearscreen (0)
|
|
|
|
CLS color
|
|
|
|
clears screen using ROM routine using color
|
|
|
|
=================
|
|
VGI Rectangle (1)
|
|
|
|
RECT color1 color2 x1 y1 x2 y2
|
|
|
|
draw filled rectangle from (x1,y1) to (x2,y2)
|
|
|
|
color1 and color2 are drawn as alternating colors (horizontal stripes)
|
|
|
|
x1 must be < 255. relative drawing is used so x2 can go to
|
|
the edge of the screen (279)
|
|
|
|
Unlike the other routines, this one uses custon horizontal-line
|
|
routines for speed so much faster than the ROM line routine
|
|
|
|
==============
|
|
VGI Circle (2)
|
|
|
|
CIRC color cx cy r
|
|
|
|
Draw a circle of color with center (cx,cy) and radius r
|
|
|
|
Circles with radius 0 will give an interesting non-circle effect.
|
|
Bresenham circles are drawn and so certain sizes don't look the
|
|
best. Also if the radius is too big things might break
|
|
as the 8-bit unsigned int oveflows
|
|
|
|
=====================
|
|
VGI Filled Circle (3)
|
|
|
|
FCIRC color cx cy r
|
|
|
|
Draw a filled circle of color at location (cx,cy) with radius r
|
|
|
|
=============
|
|
VGI Point (4)
|
|
|
|
POINT color x y
|
|
|
|
Draws a point of color at (x,y)
|
|
|
|
Note, X can be up to 279 here (the color is overloaded behind
|
|
the scenes to support this)
|
|
|
|
The last point you draw is the starting point for LINETO
|
|
|
|
==============
|
|
VGI Lineto (5)
|
|
|
|
LINETO x y
|
|
|
|
Draws a line to (x,y). The starting point and color come from
|
|
the last POINT command.
|
|
|
|
Note X cannot be > 255 so it can be trouble drawing at the right
|
|
edge of the screen. POINT can go up to 279, so you might be able
|
|
to get what you want by drawing from right to left
|
|
|
|
==========================
|
|
VGI Dithered Rectangle (6)
|
|
|
|
DRECT c1 c2 x1 y1 x2 y2
|
|
|
|
Draws a rectangle, but this time the two colors are raw bitmaps
|
|
for the output colors, not one of the Apple II colors. This lets
|
|
you do fancier dithered color patterns, but it's really hard
|
|
getting dither patterns that look nice.
|
|
|
|
|
|
=========================
|
|
VGI Vertical Triangle (7)
|
|
|
|
VTRI color vx vy xl xr yb
|
|
VTRISK color vx vy xl xr yb skip
|
|
|
|
Draw a flat bottom filled triangle of color.
|
|
The top vertex is at (vx,vy)
|
|
The bottom goes from (xl,yb) to (xr,yb)
|
|
|
|
If your triangle is too tall you might get moire effects.
|
|
|
|
This was much simpler than a proper filled triangle routine.
|
|
|
|
The skip variant adds SKIP as an X increment instead of 1
|
|
In memoy the skip is encoded in the high nibble of color
|
|
|
|
===========================
|
|
VGI Horizontal Triangle (8)
|
|
|
|
HTRI color vx vy yt yb xr
|
|
|
|
Draw a flat-sided filled triangle of color.
|
|
The side vertex is at (vx,vy)
|
|
The opposite side goes from (xr,yt) to (xr,yb)
|
|
|
|
|
|
==================================
|
|
VGI Vertical Striped Rectangle (9)
|
|
|
|
VSTRP c1 c2 x1 y1 x2 y2
|
|
|
|
Draws a rectangle, but this time the two colors are raw bitmaps
|
|
for the output colors, but to use even/odd columns.
|
|
On apple II this allows repeating pattern, but since it's a multiple
|
|
of 7 you can't get true stripes (for that we'd need a 4-byte
|
|
repeating pattern)
|
|
|
|
=============
|
|
VGI Line (10)
|
|
|
|
LINE color x1 y1 x2 y2
|
|
|
|
Draws a line from (x1,y1)
|
|
|
|
Note, X1 can be up to 279 here (the color is overloaded behind
|
|
the scenes to support this)
|
|
|
|
The last point you draw is the starting point for LINETO
|
|
|
|
=============
|
|
VGI Line Far (11)
|
|
|
|
LINE color x1 y1 x2 y2
|
|
|
|
Draws a line from (x1,y1)
|
|
|
|
In this one X2 must be > 255
|
|
|
|
============
|
|
VGI End (15)
|
|
|
|
END
|
|
|
|
this tells the drawing routine that we are done
|
|
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
Size comparison:
|
|
|
|
VGI data Captured+Compressed compressed autoconvert
|
|
======== =================== ======================
|
|
clock 385B 1228B
|
|
rocket 623B
|
|
door 189B
|
|
book 212B
|
|
firep 486B
|