Тёмный

How "oldschool" graphics work, part 2 - Apple and Atari 

The 8-Bit Guy
Подписаться 1,4 млн
Просмотров 2 млн
50% 1

In this episode I cover Apple II and Atari 2600 graphics modes.
/ the8bitguy

Опубликовано:

 

30 авг 2015

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 1,3 тыс.   
@cutemimi25
@cutemimi25 5 лет назад
For those who don't know, this was the last video before he changed his channel name from "TheiBookguy" to "The-8-bitguy"
@gh5643
@gh5643 4 года назад
thanx for clearing that up
@ThommyofThenn
@ThommyofThenn 4 года назад
thanx for clearing that up
@briangoldberg4439
@briangoldberg4439 4 года назад
i'd like to pretend i'm too cool to care about that, but i was actually wondering
@eng3d
@eng3d 4 года назад
Nah, it was his evil twin
@idontknoeausername1624
@idontknoeausername1624 4 года назад
@@mattasaccount1663 redditors amirite
@LGR
@LGR 9 лет назад
These have been awesome. I _really_ hope you do the video on CGA/EGA/etc modes for IBM PCs!
@Anonq-jy3re
@Anonq-jy3re 9 лет назад
Hey Lazygamer reveiws! I just finished watching one of your vids and I don't even know how I just idk xD #illuminati anyways Hi!
@garetclaborn
@garetclaborn 6 лет назад
SVGA was so fun
@Aqua_247
@Aqua_247 4 года назад
Well he did that video idea
@FODTony
@FODTony 4 года назад
didn't think i'd see you here
@daywalker3735
@daywalker3735 3 года назад
LGR!!! Love your channel bro!
@Simonschreibt
@Simonschreibt 9 лет назад
As far as I know, the ghosts in Pacman where "blinking" because only one sprite (out of the 4 ghost sprites) where rendered per frame. But this "optimization" makes them look more "ghosty" :)
@The8BitGuy
@The8BitGuy 9 лет назад
+Simonschreibt Correct. The 2600 didn't have enough sprites to render them all at once, so it had to do a time-share.
@bobnoel
@bobnoel 9 лет назад
+Simonschreibt The pacman game as it was sold was only a prototype. A programmer came up with a proof of concept, showed it to management and management decided to go with it instead of letting the programmer actually finish the game.
@zackarhino17
@zackarhino17 9 лет назад
+bobnoel *cough cough* EA *cough cough*
@ronwilliams357
@ronwilliams357 9 лет назад
+bobnoel Atari Pacman wasn't unfinished, it's that they couldn't have the same maze because of technical limitations (not enough vertical pixels if they kept it vertical, and not laterally symmetrical (needed for background graphics) if maybe they laid it on its side). Not having the same maze meant it simply sucked. The build up and disappointment when it was released embittered an entire generation of people.
@jimmoores7883
@jimmoores7883 9 лет назад
+bobnoel According to 'Racing the beam', it was _based_ on a prototype rather than giving the programmer time to rewrite from scratch. It also had to fit in a 4k ROM which limited the functionality. What's really amazing is how much better Ms Pacman was.
@Paradox3627505
@Paradox3627505 6 лет назад
As a kid during the 80's, this stuff seemed like magic and it always had my mind wondering "how'd they do it?". Thanks to the internet and people such as yourself posting content like this, I can finally understand. It's calming to learn how this work. Thank you.
@connro
@connro 8 лет назад
RIP the iBook Guy. He will be dearly missed. Luckily, his clone (the 8-bit Guy) is here to keep the channel alive.
@zacharycalina338
@zacharycalina338 5 лет назад
He is the same. Duhh...
@happyone234
@happyone234 5 лет назад
@@zacharycalina338 WOOOOOOSH
@candiepunk1686
@candiepunk1686 5 лет назад
@@zacharycalina338 wooooosh
@leothepeo
@leothepeo 5 лет назад
@@zacharycalina338 woosh
@manosmichalopoulos5252
@manosmichalopoulos5252 5 лет назад
@@zacharycalina338 you will get woooshed for eternity
@AlexMeyersVids
@AlexMeyersVids 9 лет назад
VERY informative. Love this series
@menopriezvisko94
@menopriezvisko94 3 года назад
true
@Persvicx
@Persvicx 3 года назад
oh hi alex meyers
@iamboredfor2months
@iamboredfor2months Год назад
Hi alex
@chuck-echeese6706
@chuck-echeese6706 Год назад
Bruh what you doing here?
@vwestlife
@vwestlife 9 лет назад
The Apple II used "artifact" colors -- same as with the hi-res modes of the Atari 8-bit computer systems (400, 800, XL, XE), Tandy/TRS-80 Color Computer, Dragon 32/64, and the "composite color" mode of some IBM CGA games. Atari 8-bit systems also had a trick where every scan line of the display could be in a different graphics mode. Games often used this to get more colors on the screen, or to show a status line (high score, lives left, etc.) at the top or bottom of the screen.
@bjbell52
@bjbell52 5 лет назад
What you were thinking of is that each command for a new graphic mode (represented by a display list command) had an interrupt flag that interrupts the video chip (if turned on), allowing code to execute before that graphic mode is drawn that allows you to change the graphics register to a different color.
@jessfucket
@jessfucket 5 лет назад
> Atari 8-bit systems also had a trick where every scan line of the display could be in a different graphics mode. !! Do you mean a different resolution or just a palette-swap like the CGA "cold" pallet and "warm" palette??
@corinthcomputers2848
@corinthcomputers2848 5 лет назад
@@jessfucket The Atari "display list" could change the graphics mode every scan line of the GTIA chip. Made for some very weird screens.
@MattMcIrvin
@MattMcIrvin 5 лет назад
@@jessfucket You could switch to different-resolution modes, or even between text and graphics modes (that was how Atari BASIC could put four lines of interactive text at the bottom of a graphics screen, very handy). It was also possible to swap colors in the color palette using an interrupt routine, or even to swap in a custom character set in the text modes for character graphics. And most of the graphics modes had color indirection for the colors, so it wasn't like CGA where you just had two possibilities--the particular mode might have 4 colors, but those colors could be any of 128 possibilities, and if you used display-list interrupts you could change those on different scan lines. So the fancier Atari games tended to have this mix of wildly different types of video display on different horizontal bands of the screen, and there was also a popular effect for title screens and such were you could have pulsing rainbow bands streaming down the screen. It's one of those things that screams "Atari 8-bit".
@rbrtck
@rbrtck 3 года назад
They're not exactly the same, though. The Atari 8-bits, when in hi-res mode (320x192 pixels on a standard screen, which it didn't necessarily have to adhere to, by the way) use all 8 bits of each byte, and therefore can only produce black, white, and two other colors that depend on the particular graphics chips they use and their revisions. On the Apple II series, the 6 colors are consistent and predictable, while on the Atari, 2 of the 4 colors are kind of up in the air. Fortunately, the hue control can usually get you a couple of usable colors, but 4 is still less than 6, and the _Ultima_ games, contrary to what many Atari 8-bit owners seem to believe, suffer on the Atari 8-bits in comparison to the original Apple II versions. You're lucky if you even get blue water and green forests--sometimes these colors are reversed, and there is no orange and purple (or you get orange/brown and blue but no green nor purple--it depends!). In fact, there were two versions of some/all _Ultima_ games on the Atari that reversed the colors in case that would help. Maybe Origin should have used some of the Atari 8-bits' other modes and capabilities--of which there are many--for the _Ultima_ conversions. The problem with this, however, is that the resolution would have been much lower. On the C64/C128 there was color memory that allowed it to more or less match the Apple II for the _Ultima_ series, including resolution. The Apple II, for which these games were originally designed of course, did some things better, while the C64/C128 did other things better, but they were a pretty close match concerning the _Ultima_ games, at least. In most ways and with most games they were strikingly different, and the same goes for the Atari 8-bits. No other 8-bit computer could match the latter when it came to games that were designed specifically for it, although the same could be said for the C64/C128 in different ways and with different games.
@theimp67
@theimp67 9 лет назад
Great video, did not know about the Apple graphics. I didn't know about CPU graphics either but the SLOW and FAST commands on the Sinclair ZX81 make sense now. It's amazing how old computers were a result of the juggling act where designers had to balance functionality versus affordability.
@The8BitGuy
@The8BitGuy 9 лет назад
+theimp67 Yep. I thought about including an example of the SLOW and FAST commands on the ZX81.
@pd3331
@pd3331 9 лет назад
I can tell how much time and work you put in to this. Every diagram is done great and perfectly represents what you're talking about.
@DrCat-bq6se
@DrCat-bq6se 9 лет назад
Actually, if you set the color bit when using a monochrome monitor, it would shift those seven pixel half a pixel-width to the left. It did the same thing on a color screen, Steve Wozniak generated colors by taking advantage of how the composite video signal was set up to relate color and position. You could take advantage of this to be able to get 560 pixel horizontal precision on positioning an object, even though the objects themselves were still limited to 280 distinct pixels (or 140 in color). I occasionally used the color bit to make things like smoother fonts.
@Abridgedpause
@Abridgedpause 9 лет назад
I love this series! I wasn't even around for most of these graphics but the history of it is super interesting! I hope you keep making these beyond the 3 parts, as you suggested at the end of the video. I'm all for it!
@AdmiralMaur
@AdmiralMaur 9 лет назад
"If there's enough interest" YES! Absolutely! Please continue with these videos! They're highly educational and interesting to watch!
@themaster3211234
@themaster3211234 9 лет назад
You know this is the type of stuff your subscribers want to see when your last video had over *1 MILLION HITS*!!!
@UncleChrist
@UncleChrist 9 лет назад
+James Campbell Well it did hit the front page of Reddit
@WickedMuis
@WickedMuis 9 лет назад
+UncleChrist and Tom's Hardware posted it on facebook
@Florensia8
@Florensia8 9 лет назад
+James Campbell Yea that was just cause of reddit
@brenpersing
@brenpersing 8 лет назад
I'm not big on these.
@kokeshkokesh
@kokeshkokesh 9 лет назад
Please do the CGA, EGA & VGA graphics! I still remember writing 2D demos in assembler utilizing direct access to VGA memory. I never did anything pas the basic VGA 320x200x8bit, as it was a simple write to the chip. No pages... Those were the times :)
@Phyphor666
@Phyphor666 9 лет назад
+Jachym Lukes Yeah, and it behaved like you expected. If you knew the VGA registers, they'd work the same on virtually all video cards of the time. It was only when one got into VESA resolutions that things started to get weird and hard to deal with.
@kokeshkokesh
@kokeshkokesh 9 лет назад
Phyphor666 I've just remembered how my schoolmate found some memory chips, pressed deep into his carpet. I got them from him and they fitted to my Trident VGA. With them I was able to view "images" downloaded from BBSes in True Color :)
@Fleshfeast
@Fleshfeast 9 лет назад
Definitely interested in the CGA, EGA, and VGA video
@johnnybigoode
@johnnybigoode 9 лет назад
+Jachym Lukes YES. PLEASE
@starcalibre
@starcalibre 9 лет назад
+Jachym Lukes Seconding this, I'd love to see these videos.
@chicoandtheman7599
@chicoandtheman7599 8 лет назад
Outstanding video! Very detailed & informative, but not at all boring, overly technical, or too hard to understand. Excellent job!
@tom_something
@tom_something 8 лет назад
Absolutely fascinating. A lot of it goes over my head of course because there's so much to cover, but I really like learning about these sort of limitations that developers encountered, and the different ways people addressed them using the same resources.
@2WhiteAndNerdy
@2WhiteAndNerdy 8 лет назад
Growing up through the evolution of graphics modes, I'd LOVE to see an episode on CGA/EGA/VGA/SVGA. I remember being a kid with a green monochrome screen, and just being so wowed by the glory of CGA, blown away by EGA, but my head just about exploded when seeing VGA for the first time. Kids these days just have no clue how good they have it, graphically speaking. Haha.
@NeonRazer42
@NeonRazer42 9 лет назад
You have had my interest. I want to see an episode on the NES, SNES, and Genesis era.
@PaulTheNerd
@PaulTheNerd 9 лет назад
I'm glad I randomly found your videos one day, they're interesting and fun and technical enough to keep me interested without becoming tedious. Love to see more stuff about graphics modes, but general 'how old machines did X' videos are always super interesting too.
@woohookittys
@woohookittys 8 лет назад
I love all these old tech videos dude. Thanks for breaking it down for us, and keep doing what you're doing.
@paleocomburo
@paleocomburo 9 лет назад
I'd love video's about CGA, EGA and VGA! I've done some very simple assembly programming in the early 90s and EGA really baffled me with the planar memory. VGA with mode 13 and mode X were really awesome! Now I have deeper understanding of computers I'd love another explanation to see if it makes sense to me now :-D
@MrTBoneSF
@MrTBoneSF 9 лет назад
Good video except those black lines on the left of the Atari 2600 are not because game code is running, it's just a bug in the video chip when a player object is repositioned on the previous line and the call didn't happen on a particular clock cycle.
@The8BitGuy
@The8BitGuy 9 лет назад
+MrTBoneSF - Interesting.. I've always heard that it was not enough CPU time. Not all games have the black lines. but that would make sense for why even a sprite is affected when it moves in that area.
@MrTBoneSF
@MrTBoneSF 9 лет назад
+The iBookGuy Racing the Beam if I remember correctly has an explanation of this. Also this question comes up a lot on the programming forum over at AtariAge ("why are they there?" and "how do I get rid of them"). Only games that have sprite reuse have the lines. Simple games with just two player sprites (like Combat) don't have to worry about the issue. Activision got around this by either having the kernel call the HMOVE on the exact cycle (near impossible to do in general code) or just calling HMOVE on every line so their games had a solid black border on the left. That area of the screen is usually in the non-playable space anyway since they had to leave a border for overscan on CRT tvs, so there was no harm in "window-boxing" the game. If the game naturally has a black background, you also wouldn't see the lines until the post-game color cycling (e.g. Space Invaders).
@The8BitGuy
@The8BitGuy 9 лет назад
+MrTBoneSF - Thanks for that explanation. I hate it when I get stuff wrong in my videos.
@pocpic
@pocpic 9 лет назад
+The iBookGuy Well, you got another thing wrong. The Atari 2600 ran at 160x192@60Hz(NTSC) or 160x228@50Hz(PAL).
@ronwilliams357
@ronwilliams357 9 лет назад
+pocpic Not really, it was 320 pixels wide but the background graphics were 160 wide then always mirror-imaged to form the right half. Sprites could be positioned anywhere though. Most games had that full-screen symmetry but you could do tricky things with the raster interrupt to swap in new background graphics.
@Bigelowbrook
@Bigelowbrook 9 лет назад
thanks for the trip down memory lane. It's been a long time since I've worked on these old machines!
@Andrew_G4CH
@Andrew_G4CH 9 лет назад
Things making so much sense now... I'm definitely loving this series you started!
@billkendrick1
@billkendrick1 9 лет назад
Darn, no mention of the Atari 8-bit computer's Display List Interrupts (which let you do some CPU-driven-style stuff, but without having to spend all of your time counting CPU cycles) -- color palette changes (useful for those typical rainbow color effects), repositioning sprites, etc. Also, on the Atari and many other systems, you had hardware support for vertical & horizontal smooth scrolling (so moving per-pixel, even in cell-based modes like a 40x24 text screen), redefined character sets (fonts, useful for tile-based games -- e.g., instead of using 8-9K for bitmap mode & moving tons of data around, you'd use 1K of graphics data + 1-2K of 'font' data), and the ability to point the graphics chips at different parts of RAM... on the Atari, even on a per-scanline basis. Practical example of combining a lot of these effects -- say you had a drawing that you basically 'compressed' into 4x8 multicolor cells, giving you around 160x200 pixels. It's only 1K for the font, plus 1K for the graphics data that defines which shapes are drawn where on the screen. But then say you only draw the top half of the picture. Use the handy point-wherever-in-memory (Direct Memory Access / DMA) feature, plus the "flip the characterset upside-down at basically no cost" feature, to draw the mirror-image on the bottom half of the screen. Then use some color palette changes to 'tint' your picture blue, and tweak the horizontal scroll value on each scanline along the bottom half of the screen. For less than 2KB you have a full-screen picture, in 8 colors (or more, if you do more of those per-scanline color changes), with an animated lake reflection effect. :) Such is the power of Atari's 1979 GTIA & ANTIC chips! They've aged quite well, I think!
@markshanehayden4648
@markshanehayden4648 8 лет назад
Great primer on old school computers! I miss those days (I programmed mostly for Atari 8-bit and Coleco). Atari called sprites "player/missile graphics". Four players 8 bits wide and 4 missiles 2 bits wide...but they were all 256 pixels tall (even taller than can fit on the screen!). They only had registers for horizontal position and were vertically placed by shifting the visible image within its very tall area! It was odd but allowed for tricks to vastly increase the number of sprites so long as only 4 appeared side by side at once...just define one player with multiple pictures within its 256 byte column then change the horizontal position of the player mid-scan. Atari 8-bit machines used "display list interrupts" to change not only colour pallette but even display resolution so you could have a section of text, a section of low res, section of high res etc. In some ways superior to what the C64 could do. The subject of how Atari graphics evolved (including how it influenced the Amiga) would be very interesting...from Atari 2600 racing the beam and the first player-missile graphics to the DLI and modes of the 8-bit computers and 5200 to how the Amiga was developed by the same people and evolved it to create HAM mode etc. Those pioneer engineers were amazing with the creative ways they used limited technology to do so much!
@eftimiemariusd.4698
@eftimiemariusd.4698 8 лет назад
could not agree more with this..nowadays they don't spend any time on optimizing the games/software, and it's even worse that this trend got into smartphone/tablet technology, for example the cheapest "Android" brand new phone was bloated with about 400 Mb of software just from google, instal any other app and the phone is frozen....
@rbrtck
@rbrtck 3 года назад
Actually, the C64 has raster interrupts, which are effectively the equivalent of DLIs on the Atari. It can (without any flickering) similarly multiplex its 8 sprites (each 24x21) using raster interrupts, among other things such as switching modes and changing color registers on specific scan lines--anything the CPU can do within the limited time available. I think that a great many Atari 8-bit owners/fans are unaware of this. The C64 is generally more powerful when it comes to sprites, although of course the Atari 8-bits have their own advantages over the C64. Both can do DLIs/raster interrupts, though. I'm unaware of other 8-bit computers that have this capability.
@markshanehayden4648
@markshanehayden4648 3 года назад
@@rbrtck that is true. The C64 has better sprites (more if them plus they have multi colour support). ANTIC DLIs are a bit better than VIC-II raster interrupts because you don't need to involve the main CPU every scan to change graphics modes, color palette etc. You just set up the display list program and the ANTIC does the rest. ANTIC is technically a full CPU itself and the display list is a kind pf program. As for other 8 bit computers that use similar tricks the closest is the TMS9918/9928 and Yamaha 9938. For the sprites, they actually only have 4 but in the hardware they have 32+ "virtual" sprites and reposition the 4 real sprites (8 in the 9938) depending on the current scan line. That is why sprites flicker or disappear on TI/Coleco/MSX when more than 4 or 8 are side by side. These chips only have interrupts on vertical blank though; you need to poll for the current scan line and they don't have hardware support for pixel level scrolling, although the basic acceleration routines in the 9938 help with that a bit. That is not really the same though since the raster interrupt tricks are done in hardware.
@rbrtck
@rbrtck 3 года назад
@@markshanehayden4648 You're partially right about ANTIC, in that it can perform some of the dynamic screen operations on its own, albeit the more it does, the more cycles it "steals" from the CPU via DMA (the Atari 8-bit has a special version of the 6502 that can be halted for this purpose). I wouldn't call ANTIC a "full" CPU, though--it's more like a limited, special-purpose GPU, and DLIs that utilize the CPU are required for the more powerful, complex types of operations. While the design of Atari 8-bit's graphics subsystem is more elegant, in the end there is not much difference between what it and the C64 can do in terms of dividing up the screen. Keep in mind that the much-touted DLI function always interrupts and uses the CPU, and that the C64's raster interrupt does the same thing (the latter may be programmatically more clunky, but it's still fundamentally the same thing). Neither computer's CPU is "chasing the beam" from the vertical blanking interval (that's what ANTIC and VIC-II are for).
@Spamless86
@Spamless86 8 лет назад
This series is awesome just found your videos and they are making me want to get back into programming. You are concise and informative while not becoming monotone or boring in the slightest. You got a me to sub after these two videos keep up the great work. I hope to see more of this series and will check out other stuff on your channel.
@jucieandrade8573
@jucieandrade8573 7 лет назад
Yours are some of the better explanations I ever had on this topic. Congratulations!
@belovedconsole
@belovedconsole 5 лет назад
I love how programmers of the Commodore 64, years after it's release, were able to get more colors and resolution out of it for static screens, not unlike the Amiga's HAM (Hold and Modify) mode where it could produce 4096 colors on a static screen.
@bjbell52
@bjbell52 2 года назад
I've seen a number of very nice video demos for the Atari 800 coming out of Poland.
@goncalotordo4507
@goncalotordo4507 8 лет назад
Would you consider doing a video like this for more systems like MS-Dos computers from the 90s, Sega Master System, Sega Genesis, Super Nintendo and comparing them?
@todesziege
@todesziege 4 года назад
The Mega Drive and Super Nintendo basically works like the NES but with more bits-per-pixel, and more and larger sprites. The Master System too, although it doesn't really use color palettes AFAIK, instead opting for a higher color depth in sprites and tiles (4bpp compared to the NES 2bpp -- same as the MD/SNES). Old DOS PC's basically work like what he described in the first part of the first video -- the "unusable" method that used too much memory.
@ste9474
@ste9474 9 лет назад
I've really enjoyed both parts to this series so far. Keep up the good informative work!
@WeesnoosProductions
@WeesnoosProductions 9 лет назад
Love the videos, man! You really put into perspective just how amazing older computers were, even compared to now.
@Ybalrid
@Ybalrid 9 лет назад
Well, I'm quite interested by the CGA/VGA stuff on IBM PCs ^^"
@ScottBeebiWan
@ScottBeebiWan 8 лет назад
+Ybalrid IBM PCs were only capable of CGA and Text Mode, Only machines from 1990+ used VGA/EGA.
@guerra_dos_bichos
@guerra_dos_bichos 8 лет назад
+Ybalrid please doi it!
@amoroboshi116
@amoroboshi116 7 лет назад
+Scott Blacklock EGA was introduced in 1984 and VGA in 1987, so not quite. Also, you know you could just pop in an EGA or VGA ISA card in something like the IBM 5150, right? Even 8-bit ISA sound cards like the Sound Blaster or Adlib will work fine in machines of that age.
@KasranFox
@KasranFox 9 лет назад
These videos are wonderful! Thank you so much. I'm looking forward to seeing the video on game music. Do you think you could talk about SNES graphics, in particular Mode 7?
@abandoned7501
@abandoned7501 5 лет назад
similar to NES
@BoutinMathieu
@BoutinMathieu 9 лет назад
I really like the music at the end (and your entire video of course, it is so interesting). Thanks a lot, you are doing a very great job!
@eddiepires3998
@eddiepires3998 6 лет назад
Great video. Clear and concise explanations. I still have my Sinclair Spectrum , got it to learn Z80 assembler back then. When I started as a young electronics technician, one of the hardest things was getting hold of information. Today we are so spoilt with the internet ! Look forward to more of your material
@sheppo
@sheppo 9 лет назад
Would love to see one on EGA, CGA, & VGA modes especially your thoughts on the 8088mph demo which achieves 1k colors in CGA. Great work on the vids!
@Octamed
@Octamed 9 лет назад
I vote for Amiga. There's loads of weird interesting hacks from the Amiga to talk about. All from 1985 too. HAM, Extra Half Bright, the Copper chip, the Blitter, bitplanes, reusing hardware sprites as you go down the screen. Also why it worked so well compared to a CPU bound Atari ST. This site details some amazing Copper chip tricks. www.codetapper.com/amiga/sprite-tricks/
@schmide
@schmide 9 лет назад
+Octamed I vote too. Esp for HAM (Hold and Modify) it was truly the first time I saw graphics that were photo realistic on a personal computer.
@juankenon
@juankenon 6 лет назад
Makes me sad to think about what could have been, they really snatched defeat from the jaws of victory.
@bjbell52
@bjbell52 6 лет назад
The Amiga is the big brother of the Atari 800 having it's video chip designed by the same person who did the Atari 800's video chip. Atari eventually added a copper chip of it's own.
@jakestilgard4145
@jakestilgard4145 4 месяца назад
Absolutely. Like this little gem on the Amiga 500 that uses HAM + Blitter objects and still has time to play the background music with sound effects: ru-vid.com/video/%D0%B2%D0%B8%D0%B4%D0%B5%D0%BE-JJczdYO8N1c.html And this one for 1985's Amiga 1000: ru-vid.com/video/%D0%B2%D0%B8%D0%B4%D0%B5%D0%BE-XDdMoglmUbs.html
@wtfitsdrewbritton
@wtfitsdrewbritton 5 лет назад
These videos are so interesting! I definitely have more respect and appreciation for the programmers/designers that have come up with clever ways to circumvent these hardware limitations
@MonsieurTableau
@MonsieurTableau 9 лет назад
These videos are terrific. Please keep them coming!
@Jay1001
@Jay1001 8 лет назад
Please do an EGA and CGA follow up. I love thinking about the tech that went into those old retro games of my youth :)
@Shamino0
@Shamino0 8 лет назад
+Gaming Jay Agreed. I would especially love to read about the register-level programming for these boards. The CGA card, in particular, could be programmed for all kinds of funky modes that IBM never intended. I remember one package we used in college (Micro PLATO, a coursework package) which tweaked CGA registers to produce a mode with fewer pixels horizonally, and more vertically. This often messed with the monitor's ability to sync, so we'd have to twiddle the vertical-hold knob in order to get a stable picture when using the program. There were other non-standard modes that were used by various games (like ElvenSoft's Round42). Sadly, very few of these games would play on more modern video cards, because they were using undocumented register-level hacks to produce the video modes. (I remember my ATI VGA Wonder card included a small application to put the card into a CGA-compatible mode that would let it support these modes. IBM's VGA products didn't have the ability at all.)
@Jay1001
@Jay1001 8 лет назад
+Shamino0 that's neat. I find video and memory hacks very interesting. Reminds me of back when I used to code in Turbo C and had to work out all kinds of little hacks to get my programs to run
@AmyraCarter
@AmyraCarter 7 лет назад
I played a lot of Atari games, and only noticed those black lines on a few games. You won't notice them at all in Pong...
@robercano
@robercano 8 лет назад
Great video! The previous one seemed more comprehensive, though this one still has a lot of golden information. Really looking forward to the next one. And +1 for the CGA, EGA and VGA episode!
@peanutismint
@peanutismint 9 лет назад
Another great ep! Can't wait for the sound/music episode.
@thiagoracca
@thiagoracca 9 лет назад
Amazing Second best video ever... Do one on Amiga AGA Graphics too!
@emilen2
@emilen2 9 лет назад
ditto. That would be most interesting!
@zandorius
@zandorius 9 лет назад
agreed, and HAM mode :)
@DonPidgeon
@DonPidgeon 9 лет назад
+zandorius Definitely HAM mode. I never understood that. I guess I can read it on Wikipedia now, but I'm lazy. ;)
@DogwafflDan
@DogwafflDan 9 лет назад
+Thiago Racca Me too
@Shamino0
@Shamino0 8 лет назад
+Fredrik Jagenheim The Wikipedia pages do a pretty good job. It's one of those modes, like Apple II double-hi-res, that is easier to describe (and implement in hardware) than to write software for. en.wikipedia.org/wiki/Original_Chip_Set#Denise en.wikipedia.org/wiki/Hold-And-Modify
@louistournas120
@louistournas120 8 лет назад
You should do an episode on programming languages back then. What was used for the Apple II, the Atari 2600, Nintendo, Sega master system. What did the IDE look like? I have searched for Nintendo code but could not find anything. It seems that nobody has open sourced their games from that era.
@CarozQH
@CarozQH 8 лет назад
NES games (and games for other computers and consoles from the 8-bit and 16-bit era) were almost always programmed using assembler language, which is basically giving instructions to the CPU etc.directly (whereas code in C etc. has to be compiled first.)
@BryonLape
@BryonLape 7 лет назад
I've done a few videos with AppleSoft basic using an emulator and screen capture. I do have images for C and a few other languages. I also have a II GS emulator. Anything in particular you want covered?
@louistournas120
@louistournas120 7 лет назад
Bryon Lape Thanks. I am checking it out now.
@BryonLape
@BryonLape 7 лет назад
louis tournas Thanks. I am trying to find the C compiler images I've used before. Have some ideas for C code on the Apple.
@foxymetroid
@foxymetroid 7 лет назад
There are different "levels" of code. First is "machine code", which is the lowest level. It's literally nothing but 0s and 1s (or hexadecimal). It's the hardest to use, but takes up the least amount of RAM (and ROM space) because the CPU doesn't have to convert anything. Machine code was mainly used in computers from the 50s and 60s. Next is "Assembly". These are machine-specific codes, used mostly in old systems that didn't have that much RAM. These hardware-specific languages used actual words instead of 0s and 1s, but were still difficult to learn and master because they were based on how computers operate instead of how human minds operate. That made them extremely efficient when it came to RAM usage. Next are the languages you might be more familiar with, like C, Java, and BASIC. These are designed to be used in as many machines as possible. They, with a few intentional exceptions, were designed more with how the human mind operates, which made them easier to master than machine code or assembly. They are also more taxing on the CPU because the CPU had to convert the code into "machine code" before it could be used. Finally, you have programs that convert user input into useable code. Examples include Raptor and Warioware DIY.
@alvaromedinagarcia
@alvaromedinagarcia 4 года назад
I love that your videos have so many languages available for subtitles. Thanks!
@klhudson9910
@klhudson9910 8 лет назад
You are the best computer guy to talk to. I understood everything that you said and you kept it interesting. You should give lectures!
@Phloxx1
@Phloxx1 8 лет назад
Do you know what kind of programs they used to code 8-bit games, or even 3d games for the Nintendo 64?
@oldguy9051
@oldguy9051 7 лет назад
Most 8-bit games back at the time were coded in assembly language. This means they used a so-called "assembler" (mostly a "macro assembler" that was a bit more comfy. Some games were also coded in BASIC or other languages and then compiled (mostly strategy games etc.) - but most action games were done in assembly language. Very CPU dependant! The N64 was mostly coded in a "higher level language" like C or C++, to my understanding, but for some time critical things you still had to use assembly language. The problem isn't the 3D per se - it's that the bigger a project gets, programming in assembly language gets more and more time consuming and as the machines get faster you don't need the fastest speed for everything.
@rbrtck
@rbrtck 3 года назад
@@oldguy9051 A bit later on, many developers did their work on more powerful 16-bit computers, and used cross-assemblers and even cross-compilers (for languages like C) for the 8-bit computers. Additionally, BASIC was sometimes used wherever they could get away with it, and compiled BASIC for less CPU-intensive parts of games wasn't unheard of. But yeah, a lot of assembly/machine language was necessary to get the most out of the 8-bit computers.
@MichaelShulski
@MichaelShulski 8 лет назад
I think it's called chasing the beam. Atari programmers were beasts
@ed10523
@ed10523 9 лет назад
This is So interesting. I have shown these videos to my son who's 19 and loves the old systems. Thanks for showing us.
@HeroicPunk
@HeroicPunk 9 лет назад
Yet another fascinating video. Keep up the great work. Can't wait for the next one. *thumbs up*
@randomtravelvideos
@randomtravelvideos 9 лет назад
1:56 notice the emphasis on the H
@eyitsaperson
@eyitsaperson 7 лет назад
whyte
@carl_the_
@carl_the_ 6 лет назад
wHite
@kwc0435
@kwc0435 Год назад
cool wHip
@memorekz
@memorekz 9 лет назад
Please do the Amiga too! The Amiga had the most wonderful graphics of any machine in the late 80s, and had things like the blitter, HAM6, EHB modes, multiple simultaneous resolutions, planar graphics. The list goes on!
@bjbell52
@bjbell52 5 лет назад
Yes, the Amiga. The Atari 800's big brother.
@Mikebumpful
@Mikebumpful 2 года назад
@@bjbell52 Low blow dude, low blow…
@jakestilgard4145
@jakestilgard4145 4 месяца назад
@@Mikebumpful No, he's right. The Amiga really is the direct relative of the Atari 800: ru-vid.com/video/%D0%B2%D0%B8%D0%B4%D0%B5%D0%BE-WUQ1mcyYbdk.html
@thevdevitor
@thevdevitor 8 лет назад
Your two videos were awesome. Made me respect even more the oldshool graphic artists
@spiesonmars
@spiesonmars 2 года назад
Excellent series - thanks! Used to play games in the 80's on those machines and had no idea how complicated graphics modes really were!
@AzzurraIrisLeaMonde
@AzzurraIrisLeaMonde 9 лет назад
Please normalise your volume levels! Thank you.. : )
@RedVisor1
@RedVisor1 9 лет назад
+Bluewave256 Agreed. I had to keep turning up the volume during scenes when the iBook Guy was off camera, but then had to hastily turn it down when he was back on camera. This was something that should've easily been caught and fixed in post-production.
@Wizardofgosz
@Wizardofgosz 6 лет назад
I'm more bothered by the environment change (going from an echoey room to a more silent room for voiceovers) than I am by the volume changes. I'm an audio engineer and I find the audio in most channels' video to be lacking. It's almost an afterthought.
@AvariceOverlord
@AvariceOverlord 5 лет назад
Isn't it weird how we've came along way in digital advancements and video editing.... But people still can't sort out audio-leveling in videos?
@igorthelight
@igorthelight 5 лет назад
4:09 - I don't think that on modern system it will use 90% of CPU. 1920x1080 = 2 073 600 pixels. Every pixel has three 1 byte colors (RGB). So, 3 * 1 * 2 073 600 = 6 220 800 colored subpixels in frame. Most monitors are 60 Hz, so 6 220 800 * 60 = 373 248 000 calculations in second. Is it much for modern 4-8 core 3-4 GHz CPU? It will take like 10-20% from one core. Correct me if I'm wrong.
@allmycircuits8850
@allmycircuits8850 5 лет назад
90% came from structure of video signal: these 90% are when ray is visible and 'draws' a picture, while another 10% it's off and performs 'flyback' coming right to left and at the end of frame from bottom to up. That time between frames is best for actual computing because your code doesn't get interrupted after just couple of microseconds. I highly doubt modern CPU could change context just after sending out another pixel, that's pretty slow operation: push all registers to stack, change SP, pop registers from another stack, etc. It would easily take 10 clock cycles and that's how much is left to draw each pixel. I'm not even sure 10 cycles is enough for each pixel, because CPU here tries to perform at least some clever decoding (for ex. JPEG image on the fly), so it's not as simple as mov from memory, other way we wouldn't need this CPU-assisted mode after all! So it's safe to think one of cores would be 90% busy drawing graphics even now.
@ultracat2375
@ultracat2375 9 лет назад
very well explained and polished video. looks like you put a significant amount of effort into it. kudos to you sir.
@alexparris7769
@alexparris7769 5 лет назад
dude. this was invaluable for a nerd like myself. I've always been terrible with coding but I am always curious and wanting to learn. This broke everything down to such an easily comprehensible video. Thanks for your time!
@Mcflapphypants
@Mcflapphypants 8 лет назад
was that a thing from ben 10 at 5:01? lol on a commodor? xD
@DRSDavidSoft
@DRSDavidSoft 8 лет назад
+Realization Fourarms, how did it end up there?
@JamesJAKAZeldaboy14
@JamesJAKAZeldaboy14 8 лет назад
yes, it was Four Arms, Commodor made.
@JimLeonard
@JimLeonard 9 лет назад
It happens 60 times a second, not 30. But otherwise, very nice video and nice visual explanation of the Apple II graphics mode.
@64jcl
@64jcl 9 лет назад
+Jim Leonard , yes for NTSC it happens 60 times a second, for PAL it happens 50 times per second. That is why the speed of the 6510 CPU in the C64 is also different between NTSC and PAL. But the television is only able to update them at 30 frames and 25 frames per second - and uses an interlaced fields alternating between which lines to update. When hooking up an old system to a new monitor you can clearly see this interlacing going on resulting in a jagged look for animation.
@JimLeonard
@JimLeonard 9 лет назад
Each field is a new image; the graphics are updated and displayed 60 times per second on NTSC systems (actually 59.94).
@MrTBoneSF
@MrTBoneSF 9 лет назад
+64jcl That artifacting is actually because newer sets misinterpret the output of old consoles as 480i instead of 240p.
@Shamino0
@Shamino0 8 лет назад
+Jim Leonard 60Hz per field, but due to interlacing, it takes two fields to render each frame, so there's a 30Hz frame rate.
@JimLeonard
@JimLeonard 8 лет назад
Do you agree that there are 60 competely different images generated by the hardware per second?
@camilowish
@camilowish 9 лет назад
This is really interesting. Looking forward for more. Excellent video and as a teacher myself, I can tell you that your explanations are clear and concise. Thanks again for the videos and keep up the good work!
@jonathanquarles8604
@jonathanquarles8604 8 лет назад
Hi, I found this video really interesting and informative! I like the way people come up with really inventive ways to manage resources. Also, I like the new channel name; it makes sense with the info you're covering now.
@PetCreeer
@PetCreeer 8 лет назад
Wtf why is ben ten in this video
@joro407
@joro407 7 лет назад
it existed 30 years ? thought it was from 2005 or smth like that
@ArloMathis
@ArloMathis 7 лет назад
Because enthusiasts will take it as a challenge to make art using old limitations, on an actual machine.
@moelester1997
@moelester1997 4 года назад
4:10 "description: makes video" r/technicallythetruth
@Eduardo1007
@Eduardo1007 9 лет назад
Great content and explanation, I'm in line for all the old-school videos to come!
@traustitj
@traustitj 9 лет назад
I can't wait for your next episode and would love to see more
@h.celine9303
@h.celine9303 7 лет назад
Cool, your Dislikes are displayed binary. Only 5, good work. ;)
@garetclaborn
@garetclaborn 6 лет назад
101.......................................ugh OMG CORNY lol
@vittosphonecollection57289
@vittosphonecollection57289 4 года назад
256
@AcrOfSpades
@AcrOfSpades 9 лет назад
But how do modern day graphics work though? >_>
@leeemattyrs4708
@leeemattyrs4708 9 лет назад
MS Paint bruh
@leeemattyrs4708
@leeemattyrs4708 9 лет назад
Very complicated math and highly skilled artists, including modeling, textures, environments etc.
@BassappsDeutschland
@BassappsDeutschland 9 лет назад
+AcrOfSpades we don't have these memory limitation anymore bruv, game design is a joke these days compared to what the smartest engineers did back then in order to produce a proper game
@TimLesher
@TimLesher 9 лет назад
+BassApps Oh, hardcore optimization still exists. It's just that some of it is done by the programmers who write the drivers.
@BassappsDeutschland
@BassappsDeutschland 9 лет назад
Tim Lesher if you compare today's growth of performance of what's considered a "standard" computer with the graphics of video games you will notice that the demand of new hardware stands in no relation to the "improvement" of the games. Games from 2010 look pretty much like games today, but now look at 2010's and today's specs of your computer. It's a shame that, instead of writing efficient code, developers rather make people buy better hardware so they can write even messier code.
@BigIslandLavaPioneers
@BigIslandLavaPioneers 6 лет назад
Tremendously awesome videos! Fascinating information, but I got super excited when I saw Ultima. I can honestly say that those games are what got me excited about computers and quite literally steered me toward my career and shaped my life.
@LuizSiqueira
@LuizSiqueira 8 лет назад
Congratulations for your work, great video. This kind of material makes me feel nostalgic, I miss my MSX.
@DyoKasparov
@DyoKasparov 8 лет назад
I ran Windows 7 w/o GPU, it is possible, you really could see how the CPU gets everything on scren pixel by pixel. WinXP ran worse than 7 tho.
@phantomlobotomy1157
@phantomlobotomy1157 8 лет назад
CPU's have a small chunk that are dedicated to graphics. So it's a really small GPU...of course, those are leagues ahead of dedicated GPU's from decades ago...
@Architector_4
@Architector_4 8 лет назад
My brother's notebook has Intel Core i5 CPU @2.4GHz with 4 cores, and nVidia GTX520MX GPU. It used CPU as a GPU too for a long time, having my brother swearing on low performance of games, until he found out about that and switched to "full performance" mode to use that GPU too. So yeah, some notebooks work with ignoring GPU by default. I think my dad's netbook(or idk, really small notebook) doesn't even have GPU at all and uses CPU in the same way.
@funky3ddy
@funky3ddy 9 лет назад
Too oversimplified.. I like simplicity, but go deeper! :)
@markwetmore486
@markwetmore486 9 лет назад
Make the additional facts, please! I love this series! This is some really interesting behind the scenes stuff. I want all your graphics and game knowledge!
@creature_73l32
@creature_73l32 9 лет назад
Loving this series, can't wait for the next one.
@ratchetxrc
@ratchetxrc 9 лет назад
I am loving these videos. A lot of answers to things I always wondered! Whatever you cover next will definitely be interesting because this stuff is just fascinating :D
@dirttechnology3418
@dirttechnology3418 8 лет назад
Been enjoying your videos lately Good length, not too boring. Love your channel :D
@Derceto00
@Derceto00 8 лет назад
Great string of videos you have. Easily got my sub. Plan to dive through everything you have. Thanks for these great and informative videos!
@pnak0tic
@pnak0tic 9 лет назад
I really like those videos and can't wait for the next one. Thanks for your insight, those are super interesting
@thegaryjay_yt
@thegaryjay_yt 8 лет назад
I really appreciated what you posted in the last video about sprites. Right before you covered it, I was typing up a question on how they were able to move above an area that was only allowed 2 colors :D
@RobCozzens
@RobCozzens 9 лет назад
You do a really nice job hitting the sweet spot of level of detail.
@AntonioAlaniz715
@AntonioAlaniz715 9 лет назад
Cool videos! Looking forward to seeing the next one!
@ascendingmoth
@ascendingmoth 5 лет назад
I never thought I would find something like this interesting, but I really enjoyed this. Nice video!
@MattFurniss
@MattFurniss 9 лет назад
Great series so far! Please make more. Thanks!
@EterniaWolf
@EterniaWolf 9 лет назад
Seeing CGA, EGA & VGA graphics would be awesome! Just wanted to also say I love these videos! They are very informative and I enjoy learning about different types of graphics.
@LancePickup
@LancePickup 9 лет назад
REALLY great video David! Keep up the good work.
@obeythelaw5504
@obeythelaw5504 5 лет назад
Great Job. Brings back memories. I teach computer science in High School. (AP, IB, Gen Ed) This would blow kids minds today.
@mrbronstein
@mrbronstein 6 лет назад
Excellent! Really enjoyed listening to this and part I
@ianmccown2934
@ianmccown2934 8 лет назад
Your one of the smartest guys on RU-vid in my opinion. watching some of your other videos, your able to to put new things into an old product to improve it, and your able to take things apart and fix these things, I apologize for not being specific but there's many different videos, but regardless, it's all rocket science to me at points, I can't imagine the schooling you must of went through to know all of this.
@MageOfTheOrder
@MageOfTheOrder 8 лет назад
Nice video. It has me all nostalgic. I remember Richard Garriott explaining colours on the Apple ][ and how he drew the Ultima shapes on graph paper to map each pixel and colour.
@DanielDavissynthman
@DanielDavissynthman 9 лет назад
This is really great. Nicely made. Love your channel.
@ThatReasonableGuy
@ThatReasonableGuy 9 лет назад
MORE! I'm really enjoying these, great work!
@triplethreatgaming8741
@triplethreatgaming8741 9 лет назад
Really interesting stuff, thank you so much for sharing with us! YES! We'd love more!!!
@tsarcastic3722
@tsarcastic3722 9 лет назад
This is a great series! Please keep up the good work.
@landmarkq
@landmarkq 6 лет назад
i watched this video about 15 time & am ready to watch it 1000 time so much greatness in this video. thanks so much
@Talasas
@Talasas 9 лет назад
I've always been interested to learn about this and would love to see a video on CGA/EGA/VGA. Keep up the great work!
@CrystalMcNair
@CrystalMcNair 7 лет назад
Haha, oh wow... I got distracted by the awesome tracker music in the previous video (Part 1), and spent an hour downloading all my old favourites before finally returning to this video. Love hearing the tracker music in your videos.
@Main710
@Main710 9 лет назад
Can not wait for the sound & music episode!
@BigMeanyVids
@BigMeanyVids 8 лет назад
Thanks man. My 8, 12, and 15 year old loves these vids. It got my 12 year old girl excited enough she is actually playing with simple graphics now on an Arduino and 8x8 matrix display. She is really starting to appreciate what you were saying as a result.
Далее
CGA Graphics - Not as bad as you thought!
11:27
Просмотров 2,3 млн
How Old School Floppy Drives Worked
15:08
Просмотров 2,8 млн
Atari 2600 Programming is a NIGHTMARE
15:38
Просмотров 14 тыс.
How Oldschool Sound/Music worked
8:44
Просмотров 3,2 млн
JPEG is Dying - And that's a bad thing
8:09
Просмотров 13 тыс.
How Vintage Game Controllers Worked
10:35
Просмотров 1,1 млн
Game Boy Graphics & How To Code Them
9:02
Просмотров 94 тыс.
What was Coding like 40 years ago?
29:05
Просмотров 1,7 млн
The Atari 7800 is More POWERFUL than the NES?
16:29
Просмотров 93 тыс.