Skip to content

MuffinHop/dosengine

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

dosengine

This is a small project to use as a lazy example piece for future 386-Pentium class demoscene demos. Uses Midas Sound System Library for sound(Supports Sound Blaster's and Gravis Ultrasound) so you'll have to include it to your Watcom project file. Also has PC Speaker support for fun. Hopefully this project will be finished until Assembly Summer 2016, since they MAY HAVE a Oldschool/Midschool demo compo that allows Pentium-class demos. This project will only support VGA. If you wish to support SVGA you'll have to do research for that yourself. Uses a modified version a public domain GIF loader for loading GIFs.

Personally I prefer 486+VGA(ISA)+GUS so that is my target platform for this engine. Atleast 6 Mb of RAM is required, that seems to be the amount of RAM Future Crew's Unreal requires so I am personally OK with that amount.

VGA

Mode 13 - Regular Chunky Mode

Straightforward mode to handle pixels but you have less freedom to change resolution, nor can you access more than 64 Kb of Video RAM meaning no page flipping is possible, this means you'll have to spend a bunch of CPU cycles moving double buffer data before VGA-card begins to write video data onto screen. Also to my understanding Mode 13 is slower than Mode X in read/write time. Due to 16:20 resolution on 4:3 screens pixels will be a bit more wide than tall, a ka fat pixels. Supports 8-bit images easily (a GIF loader and displaying those images functions exists within the demoengine).

Mode X - Unchained Mode

Memory is split into four groups. For every close group of four pixels each is split into seperate planes. So one byte of display memory can represent more than a single pixel. By writing into all planes one byte write will fill up four pixels so this is ideal for quick fills like flat shaded polygons. Understanding Mode X will take time, mastering Mode X will take even more time and it's not always the best option but generally is the recommended one. Unlike bitplane graphics unchained byte still repesents one color. I suggest reading chapters 47-49 from Michael Abrash's Graphics Programming Black Book(PDF online) or use google. Mode X will allow you to change resolution more freely and you have access to more Video RAM. By changing where VGA card starts reading video memory you essensually can have double buffer memory on video memory. That means you don't have to move data around and spend those valuable cpu cycles. All you have to do is tell VGA card where to start displaying video memory beforce vertical retrace starts.

Fake hicolour 18-bit mode

This is entirely software baked visual illusion and not a real screen mode. Normally each row of pixels has different color component and on a old CRT monitor these colors will blend together. On this demoengine I use a bit different way of blending colors by dithering to make it look a bit more realistic on TFT monitors but not much can be done to make it look good on modern monitors.

EGA mode with VGA palette

This is basicly EGA 320x200 mode but most VGA cards support using VGA palette register to access 24-bit palette in EGA mode. You still only can use 16 colors / frame. Pixels are drawn to bitplane planars similar to Amiga. This mode can be used in some cases to have fast drawn sprites on screen.

Why page flipping on VGA and unchained may not help

Engine will need to take into consideration the fact that viewer may be using ISA or EISA cards for graphics. They both have bus speed of 8.33 Mhz(Maybe overclocked to 12Mhz) and have a bus length from 8 to 32 bits depending on hardware. So it may be a good idea to avoid writing to video memory unless you're writing in a fast fill loop even if you are writing into a page flipped buffer in video memory. Therefor having buffer in regular memory may be a smart idea. Once writing to RAM buffer has been finished you copy your RAM buffer data onto VRAM buffer in a fast loop and after that flip the address. On PCI and VLB hardware this really is not an issue since speed they have is good enough. RAM speeds on most 486 motherboards can be accessed at 20-40Mhz in most cases with 32-bit bus.

So what this means

My 486 PC has an EISA VGA card so I've decided to target that card therefor I have to use buffer on regular RAM and not in video RAM. Once I'm done with the buffer I copy it onto Video RAM with 32-bit chunks. On regular ISA this 32-bit pushing might cause a cycle of extra waiting but this should not be too bad. Because I'm fairly fine with a bit fat pixels I don't mind using mode 13h chunky mode.

About

dosengine

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages