I had AMOS when I was a kid, wish I had some books or that tutorials like this existed. I didnt even know what are Procedures and used all variables as global. Great retro channel, instant subscribe.
Fantastic explanation. The community needs more videos like this. Tutorial videos were indispensable when I was learning Blender and now that I am coming back to AMOS after a 20+ year break the more help with understanding the better. Trying to discover methods for effects can be fun and rewarding but it can also waste a lot of time.
Thank you and best of luck with your projects. Please subscribe if you've not already, because the next AMOS video will explain all the translucent effects in depth.
It is hard to believe that in 2020 AMOS still got so much followers. Amiga is amazing computer not only because got a great games. It is amazing thanks to AMOS that defined many of programmers.
Amos is really easy to use and was phenomenally ahead of its time, but it's slow, even when compiled. A shame they never made Amos 3.0 with an updated compiler that translated to more optimised assembly. Blitz was quite a bit faster, but it was harder to use, so if Amos could have closed that gap between speed and convenience it would have been the best!
@@nebularain3338 Even I could use it , did a half done Dungeon master like game which I feel sad I never completed because the the Harddrive died on me. (20 MB HD lol).
I agree with both of you. There were games with great background effects on Amiga, but it's true that there could be more games using Amiga's capabilities. Unfortunately only few developers back in the day knew how to use Amiga's custom chips which were years ahead of anything else back then. Sometimes floppy medium was a bottleneck that required much more memory for the games compared to cartridge based consoles. That's why some ports of arcade and console games were rushed and mediocre. Some games needed optimizations in the engine to use Amiga's capabilities and optimizations for floppy medium. In most cases teams assigned to port games lacked time and knowledge about Amiga hardware to make a proper port.
Age 11 I tried so hard to get on with Amos. Sadly I wasn’t focused enough at that age. Though going through the process and manuals etc set me up for a love of coding in the future.
Beast 1 on the amiga also used the copper chip to add greens along the bottom of the screen on level 1. I realised this when I was cloning level one using blitz Basic 2. Im wondering if redefined text characters could also be used for more graphical effects in the background? Since they are 2 colour as well. The commodore 64 often used text to create a background layer. So, with Amos, redefine 8 text characters with a pattern that shifts/wraps around horizontally. You then draw the relevant character number along the screen.
Thanks very much. Have you seen our more recent videos about the game we started using Scorpion Engine? With much easier use (for non-programmers like us), more hardware banging features readily available for cool parallax and translucent effects, and the ability to make games for Megadrive as well, Scorpion Engine is now our de facto retro game authoring tool of choice.
Oh the memories. I loved AMOS back in the day. Sadly my little amateur games are all lost. :( This is pretty impressive though. I love the creativity, and the palette choice - colorful and not too dull like some other Amiga games.
Am I getting this right that the far background mountains are in fact technically just part of the foreground layer image, but, by only using certain colours and bit planes or whatever, you can create an illusion that it's two parallax layers? If so, is this something unique to Amiga, or can any system with say normally 4bpp background tiles assign some of the colours in the palette one way and some the other stuff to create a similar trick of what looks like two backgrounds out of a single background layer tileset? I know there's mention of bitplanes on SNES for example, so could those bit planes and the standard 16 colours per tile be exploited similarly to how they are in Agony and your game to make one layer look like two?
Sorry, I don't know enough bout the SNES hardware, but presumablu the roadblock there would be blit speeds. While the SNEs has fantastic hardware for sprites and its existing tile based layers, I've never heard of it having anytihng dedidicated to blitting (drawing) to bit planes so if the main processor of the SNES had to it it, it would likely be extremely slow. The Amiga was specifically designed for fast blitting and planar graphics (full control of each bitplan independantly if desired) But I suggest talking to an experienced SNES developer. My guess is though you'd just be better off using the SNES's default hardware power as intended with I think up to 3 playfields whih would could independantly line scroll, and combined with some sprites, create the illusion of a great many layers of scrolling. You could also add in animated tiles to simulate other layers of scrolling.
@@bitbeamcannon2468 Yeah, it's up to four standard full-screen fully-overlapping layers that can all row/line scroll independently with varying colour depths depending on the background mode (four 2bpp layers with 24 visible colours per layer and 96 colours total for all backgrounds in Mode 0 for example), plus the standard up to 128 4bpp sprites with their own additional 120 visible colours as per usual (32 max sprites per scanline and 272 max sprite pixels per scanline). And there's some extra tricks that are possible by exploiting the high/low per-tile priority of each layer as well as the main/sub screens too for additional layering and parallax. So there's still plenty of scope there. But I was just curious about the bit-plane blitting thing as that sounded interesting too. Didn't think it would be an option on SNES to be honest, else I probably would have seen it mentioned elsewhere, but figured it was worth asking anyway just in case. :)
could you please tell me, how is the sky's background gradient effect achieved ( it is not a perfect gradient but rather it has some horizontal lines on it ) ? how is this retro technique called? thanks!
Hi, The Amiga had a co-processor they called the copper chip which could do many things including change the RGB value of color indexes "during a vertical blanking gap" (basically each time the computer was done drawing each row of pixels and ready to move onto the next row of pixels to create the screen image). In this way you could trick the Amiga to display things like gradients using only one color index, by changing the color it displays at any give full row of pixels. AMOS has a "Rainbow" command which lets you control what RGB value any given color index displays at any vertical coordinate. I created a separate too program in AMOS to analyze a guide image I made and reproduce the gradient (with horizontal lines and all) as AMOS compliant Rainbow instructions... in other words I made code in Amos which generates more code in Amos ;) th-cam.com/video/VMADU2BVihY/w-d-xo.html&ab_channel=BitBeamCannon
Not yet. Our goal with the first few games is classic OCS.ECS compatibility. I think the progress being made on the AGA version of AMOS is awesome though, and I personally would love to eventually make an arcade style game which really shows off what AGA was really capable of, and in general I'm super glad the authoring systems are being developed and improved to empower people to make more and better games for Amiga. -Mike
Hello Wow nice presentation. I have a question. I suppose you work also with Deluxe paint 4 or 5..and PPaint, why do you choose Brillance to draw ? many thanks
I only used Brilliance in modern times to convert 256 color IFF images down to the proper IFF formats I needed for Amos. For making the pixel art in the first place I'd switched to Pro Motion NG on Windows based systems well over a decade ago. Back in the day I had originally used Dpaint for a couple of years before getting Brilliance and I just liked the interface and tool-set of Brilliance more.
@@bitbeamcannon2468 Ha ok cool. Thanks for your info. Can I ask other detail ? I ´m creating a very simple game with Amos Pro on Amiga 600. THe game is like Sorcery from cpc (I´m sure you know it) The fact is when I create a iff with deluxe paint, with the default palette, then I create the bob with DP4 also.. After this I go to Amos edit object and grab the iff to convert as Bob, and when I load iff and load Abk one of them lose colors... If I use get bob palette bobis correct but the background color change, if I don´t use get bob palette then bob is Ko and background Ok.. I think it´s because I have to use the same colors in both but it´s already the case (default both) What do you think ?
@@LuisDiaz-uu7xg They do indeed need to use the same exact color palette. Using the same colors is not enough, the colors must all be arranged in the same exact order in the palette, such as black for index zero etc.
It's easy to do this in X68000 with knowledge of how the bitplanes work and the using the copper co-processor to do the pallette changes ( this is the hardware equivalent of the rainbow command) the copper co-processor only had about 3 intructions and was easy to learn. and it was never hard to achieve hardware horizontal scrolling on the amiga, the hardware was setup to do this.
i had a copy of this in early 90s. no documentation. i was like 13, didnt know how to use it but tried many public domain programs by typing them out of books or bulletin boards. i did like logo and basic before that on c64 but man. i knew what this was. now 44, after 20 years as a tradie, the planets aligned and now im 1st year indy game dev. i wonder if i can use something like this today, how would you run it not in an emulate but make it usable. can u run workbench from a webpage?
You have a few options, but I highly recommend looking into Scorpion engine by Erik Hogan, which let's you develop a real retro game once and with some additional effort, export that game to real Megadrive, Amiga, Neo Geo, and the CD versions of those systems. You can also "wrap" those exported games in an emulator so to the actual end-user/player it just seems like any other windows .exe
@@bitbeamcannon2468 😮 so i could technically do this and put it in my own cabinet? wow. i have all that im just working in ue5.4... thanks for that info i use batocera and have used most of the frontend and emulators across the board. (pun intended) currently running a custom batocera plus build so i can play KI1 and 2 etc.. but also gotta have kodi and a full GUI ( i use that neonflash one)
Not with Amos, as it does not support that at all... someone would have to completely replace the copper and sprite handling in Amos, likely with Assembly code for that, but with Scorpion Engine it's absolutely possible, but even with scorpion engine I think it's currently limited to using 3 color sprites for t he back layer. The great thing is though, due to Scorpion Engine's great use of the copper, you can have 4 totally unique colors per scan-line in the repeating sprite background and you can slice it up into segments which scroll at different speeds for some really AAA quality parallax effects. Have you seen our other project canned Aeon's Legend (AKA Scorpion Boy)?
A crazy amount, especially with a really strong programmer. Take a look at Metro Siege for example, which is a combination of C and Assembly, and runs great on OCS/ECS amigas.
Isnt that normal dual playfield? Basically the blitter lines up the bits and from back to front, which makes up the final image, as long as the opacity color is there, the copper shines through
No, this does not use normal dual playfield mode. this is a single 16 color layer, using the blitter to blit the background layer in on every screen update. This puts some strong color limitations on the back layer and some on the front, but allows for some of the foreground and all objects to be 16 color bobs instead of 7 maximum which would be the case for OCS/ECS dual playfield mode.
Nice video thanks, I have a question, why don't the coppers / rainbows look like they would on a real system outside the left and right side of the viewing area? is it because of the emulator maybe? Or do you use something to prevent them from looking beyond the visible area? or it´s because just they appear in the indexed mapped colour assigned?
Some emulator settings are able to compensate for that, including by forcing a black border or making the low res screen take up the full screen instead of having a border, BUT the copper color changes only show up on the external borders of the screen if you are changing color zero, as you see in the video, I'm not changing color zero, so even on a real Amiga the borders stay nice and black. However, there was a programming trick that ECS Amiga's was capable of that could revert the color back to black on the edges, but I don't think AMOS was capable of that.
The Agony trick is indeed very effective but the loss of half the color entries annoys me a lot. 😉 You could possibly increase slightly the blitting cost of he background bit plane to regain full use of the color entries. Instead of simply blitting the bob in your background bitplane (I assume it is bitplane 0 but it could really be any bitplane, the technique still works), you would have to AND it with an additional 1 bit mask plane. This mask plane would simply be the silhouette of the foreground elements. Thus, wherever the mask is 1 (meaning there is a foreground element), the blit operation would clear the background bitplane (or set it, depending on which convention was chosen) and thus prevent the background plane to influence the color index. The added cost would be important but not enormous. Essentially, instead of using two channels: source and destination, the blit would now use three: source, mask, destination. Thus adding only 50% to the total cost of the blit (x 1.5). The mask can be constructed at the same time as he rest of the tiled background for a very small cost so mask construction is almost negligible. If there are levels which are not too Blitter intensive but require more colors, this may be worth the extra cost. Keep up the great work guys!
I forgot to mention that there is also a memory cost: the mask is the exact same size as the background image so this would double the background memory requirements. Again, in some levels this may be an acceptable compromise. Cheers!
Puoi scaricare il vero progetto Amos per questo dalla nostra pagina Amiga su bitbeamcannon.com/amiga/ Per assicurarci che potesse funzionare senza problemi con nemici ed effetti, ecc. abbiamo limitato gli aggiornamenti dello schermo (FPS) alla metà (quindi 25 per PAL e 30 per NTSC). Lo strato posteriore non è un doppio campo di gioco, utilizza una speciale modalità blitter per incollare un BOB a 2 colori sullo sfondo e il primo piano estremo è un altro schermo davanti allo schermo di gioco reale per il motivo dell'erba e gli sprite per gli alberi. To make sure it could run smoothly with enemies and effects etc. we capped the screen updates (FPS) to half (so 25 for PAL and 30 for NTSC). The back layer is not dual playfield, it's using a special blitter mode to paste a 2 color BOB into the background, and the extreme foreground is another screen in front of the real playing screen for the grass pattern and sprites for the trees. You can download the actual Amos project for this from our Amiga page at bitbeamcannon.com/amiga/ To make sure it could run smoothly with enemies and effects etc. we capped the screen updates (FPS) to half (so 25 for PAL and 30 for NTSC). The back layer is not dual playfield, it's using a special blitter mode to paste a 2 color BOB into the background, and the extreme foreground is another screen in front of the real playing screen for the grass pattern and sprites for the trees.
you can use it in combination with dual playfield if that's what you mean, but since OCS/.ECS dual playfield is only 8 indexes per playfield it's a very big price to pay.
@@bitbeamcannon2468 So, one could use 2 colors for the fixed "BOB" background, 6 colors for the background playfield, 7 colors for the foreground playfield (that could be used exclusively for drawing enemies) and 16 colors for sprites, right?
@@ProfenixStudio Yes, BUT there is another severe color limit to the method, and that is, anywhere the BOB simulated back layer is drawn, you can't use half of the available colors in that portion of the layer or it will ruin the effect. I can't remember if it's the odd or even indexes you can't use, but only every other color index will properly seem opaque over the simulated back layer made with the special bob.
@@bitbeamcannon2468 you mean all the colors of the dual playfield or only the colors of the background playfield (where I draw the bob)? In other words, as in agony, in that portion I use one of the 3 bitplanes available for the background playfield, right?
I don't plan on building on top of this engine at the time. I made it public and open-source in hopes the community will build on top of it, optimize it, and continue to share it with others. I am and will be working on additional tools and examples. Have you watched our 'rainbow ripper tool' video yet?
This game was written in Amos ?!!! The games written in Amos I remember were always some low budget, really cheesy, bad looking shootem ups :D ! With so many image generative AIs you can generate beautiful background for your games for free and create a fantastic game for Amiga. AMazing times !
This demo was made with Amos, and I had also made a SHMUP demo in AMOS, but the real DaemonClaw is currently not yet being developed for Amiga, BUT when it is made for Amiga we'll be using the same code base (and programmer) who's currently working with us to make Metro Siege, but the engine will be enhanced to support AGA specific hardware etc for DaemonClaw
There are ongoing efforts by different people and groups to make branch versions of Amos for full AGA support, editor/UI improvements, and making a windows executable that automatically opens Amos Pro on your PC in an emulated Amiga environment. Aside from that, if you don't care so much about specific ties to Amiga specifically (or Amos), there are incredible and easy to learn authoring systems out there ranging from Construct3 to Unreal Engine. I remember there had been people trying to make a literal port of Amos Basic to work and run and export for modern systems, but I'm not sure if they are still working on it, succeeded, or if it's abandonware. -Mike
Where’s all the love for Blitz Basic? In my experience Amos was slower than Blitz Basic. Maybe later versions of Amos improved performance? Note that the last time I touched either one was in the early nineties. Gorgeous pixel art BTW.
Thanks very much. Blitz is awesome but it was just all a matter of timing and convenience for me. I had already learned and began projects with Amos back then before I became aware of Blitz Basic. In other words, I greatly respect Blitz, but I'm not the right person to make any videos or tutorials about it.
OCS/ECS, but it would work the same if you used it on an AGA system. It should also be compatible with higher color-count AGA modes, but I've never tested it with any AGA extensions on AMOS,
I'm very familiar with the Amiga hardware, especially the gfx ASIC. I used to dabble with AMOS back in the day too. However I could not follow this video AT ALL. INDEXES? You sound like PC programmers. They're not tables, they're not indexes, they're color registers. I hate having to stop and mentally reconfigure. The multiple bitplanes are fetched word at a time, then each word is essentially shifted (I assume it's a rightshift), with the output bits select which color register is allowed to gate out three 4-bit groups (12 bit color for the OCS) to the color DACs. Now if you want to call than an index??? OK but that's really confusing. I'm old and cranky, I know. Did you ever really explain how the diddled plane does not affect color register selection? The only thing I can guess in that that you blit the mountain stuff *first* each time, then manually blit the other stuff atop it (and the sprites always do their automagic spritely business). We have to assume this because you never mention masking or playfields in any useful detail AFAIK. Or I missed something!
The mountain is actually blitted after the foreground is (right on top of it all) but before any characters or items, but because the the special blit setting telling it to only blit certain bit-planes, the mountain art doesn't effect the specific color registers that are used in that part of the foreground art. BTW, I picked up the terminology color indexes as a pixel artist, and not a PC programmer. I grew up with first an Adam Computer, them a C64, then Amigas, then finally Windows based PC. -cheers Mike
Thanks. You can download the actual Amos project here: bitbeamcannon.com/amiga/ You can reuse the code however you'd like, but no one can use these graphics, so please replace them if you want to make your own game or demo.
Nice "trick", but you have to say that It's unusable for a real game, because you can't draw an evolving background, only the same screen running in a loop. That's the difference between real scrolling playground, which is quite impossible to make in Amos, and an nice but useless "screen offset" like this one...
Thanks for taking the time to comment, but how do you propose this wouldn't work in a real game? The foreground could be any kind of robust evolving tile map, and regarding the background being static, I wouldn't call that a 'cheat', but a compromise to get get a parallax effect within what is possible in AMOS. Mountains in the far distance actually would appear static unless you traveled very far horizontally in a level, so that only poses a problem if you want a different type of background like a stone wall that's also close to the player, in which case the repeating sprite trick (which AMOS can't do) would be a far better method for achieving that kind of parallax on OCS/ECS Amiga.
@@bitbeamcannon2468 For the foreground (the forest), you open a 572-pixel-wide screen, within which you scroll using a "screen offset" function, that is fast because it change only the coper positioning of view in the memory. But to make a game with a real level design made up of dozens of screens to scroll through, you can't open a screen thousands of pixels wide, in particular with the 512Ko Chip Ram of the A500. This kind of scrolling use blitter operations, and it's not possible in Amos. To be perfectly honest, it's possible to do this kind of scrolling with a simple "screen offset", and a single screen twice the size of the screen, as some shoot 'em ups do, but it's rather limited in terms of scrolling possibilities. The idea is to prepare the playing field on the non-visible part of the screen on the left, little by little as the player moves to the right, copying next vertical offset lines as he goes on right, then returning to the first half of the screen in one go when the player reaches the far right. But this technique dont let you move in two directions (or more), and is also very difficult to do in AMOS.
@@plopparici3110 The next step of the demo was going to be to try to make it work using an actual tile map scrolling routine, but we had to move onto other things before we could try. Indeed AMOS forces lots of limitations on the programmer and on performance than the Amiga hardware was capible of.
PLEASE PLEASE PLEASE..... I beg you.. Make the Game FULL SCREEN and not cut off at the top to place the score there (The HUD?).... Add the SCORE and ENERGY later right ONTOP of the Action at the top like some of the other versions you've done. The background should fill the entire visible screen of a CRT TV... Pretend this is for an arcade. If possible make it Overscan so there are not visible black borders on any of the edges. This always screams professionalism, plus will look better in Emulators in the future. And by Golly...use EHB/Extra Half Brite mode for 64 colors...... you can do more if you do the Broadcast Titler 2.0 trick of layering different Public screens as one, giving you double or triple or quadrule the colors. Or at least look at ElfMania and Ruff N Tumble...the color use is superb and both are 64 colors. KUDOS for Using Brilliance.... Better than DPaint... But I suggest HIGHLY you use Brilliance 2.0 as it was greatly improved over Brilliance
Dude this is better pixelart than I have seen on stuff like the SNES. The colors are awesome.
Thanks very much. :)
@@bitbeamcannon2468 always man.
I’m actually a past Atari programmer who’s made 8 Atari games.
I had AMOS when I was a kid, wish I had some books or that tutorials like this existed. I didnt even know what are Procedures and used all variables as global.
Great retro channel, instant subscribe.
Thanks very much!
Fantastic explanation. The community needs more videos like this. Tutorial videos were indispensable when I was learning Blender and now that I am coming back to AMOS after a 20+ year break the more help with understanding the better. Trying to discover methods for effects can be fun and rewarding but it can also waste a lot of time.
Thank you and best of luck with your projects. Please subscribe if you've not already, because the next AMOS video will explain all the translucent effects in depth.
It is hard to believe that in 2020 AMOS still got so much followers. Amiga is amazing computer not only because got a great games. It is amazing thanks to AMOS that defined many of programmers.
Amos is really easy to use and was phenomenally ahead of its time, but it's slow, even when compiled. A shame they never made Amos 3.0 with an updated compiler that translated to more optimised assembly. Blitz was quite a bit faster, but it was harder to use, so if Amos could have closed that gap between speed and convenience it would have been the best!
Yes, AMOS Pro was my first real IDE (after AmigaBASIC) to learn programming ;)
@@tomaszx7760 same here! Still using it for hobby projects.
@@nebularain3338 Even I could use it , did a half done Dungeon master like game which I feel sad I never completed because the the Harddrive died on me. (20 MB HD lol).
I started with GWBasic and then EasyAMOS followed by AMOS Pro and then finally Bitz Basic.
I'm not a coder but I think that this translucent "trick" with a palette is amazing!
Brilliant work. Pity more games weren't designed like this back in the Amiga's heydey.
WHat are you talking about??? of course they were, with even more colors and tricks. Have you played: LionHeart, ElfMania, Ruff n Tumble????
I agree with both of you. There were games with great background effects on Amiga, but it's true that there could be more games using Amiga's capabilities. Unfortunately only few developers back in the day knew how to use Amiga's custom chips which were years ahead of anything else back then. Sometimes floppy medium was a bottleneck that required much more memory for the games compared to cartridge based consoles. That's why some ports of arcade and console games were rushed and mediocre. Some games needed optimizations in the engine to use Amiga's capabilities and optimizations for floppy medium. In most cases teams assigned to port games lacked time and knowledge about Amiga hardware to make a proper port.
Shadow Of The Beast! That changed the game on the Amiga!
Age 11 I tried so hard to get on with Amos. Sadly I wasn’t focused enough at that age. Though going through the process and manuals etc set me up for a love of coding in the future.
You are not alone and I have a feeling this is a somewhat common tale. Fortunately now coding is great fun!
Beast 1 on the amiga also used the copper chip to add greens along the bottom of the screen on level 1. I realised this when I was cloning level one using blitz Basic 2.
Im wondering if redefined text characters could also be used for more graphical effects in the background? Since they are 2 colour as well. The commodore 64 often used text to create a background layer. So, with Amos, redefine 8 text characters with a pattern that shifts/wraps around horizontally. You then draw the relevant character number along the screen.
Wow thanks for sharing (and the code) just getting back into amiga/amos coding and this stuff is very helpful..
Damn, that pixel art is awesome, keep up the great work :)
Thanks very much
Your welcome :)@@bitbeamcannon2468 I love pixel art over any other form of art in the world, I have dabble in some myself but I am only learning.
Looks FANTASTIC!!!! AWESOME!!!
thanks.
Wow, never thought AMOS could make games with such great quality! Pretty cool! Keep it up! 😍👋
Thanks very much. Have you seen our more recent videos about the game we started using Scorpion Engine?
With much easier use (for non-programmers like us), more hardware banging features readily available for cool parallax and translucent effects, and the ability to make games for Megadrive as well, Scorpion Engine is now our de facto retro game authoring tool of choice.
It can not. This sample is just a "trick", unusable for a real game
Oh the memories. I loved AMOS back in the day. Sadly my little amateur games are all lost. :( This is pretty impressive though. I love the creativity, and the palette choice - colorful and not too dull like some other Amiga games.
Thanks very much.
Beautiful! ☺️
Thanks!
Am I getting this right that the far background mountains are in fact technically just part of the foreground layer image, but, by only using certain colours and bit planes or whatever, you can create an illusion that it's two parallax layers?
If so, is this something unique to Amiga, or can any system with say normally 4bpp background tiles assign some of the colours in the palette one way and some the other stuff to create a similar trick of what looks like two backgrounds out of a single background layer tileset?
I know there's mention of bitplanes on SNES for example, so could those bit planes and the standard 16 colours per tile be exploited similarly to how they are in Agony and your game to make one layer look like two?
Sorry, I don't know enough bout the SNES hardware, but presumablu the roadblock there would be blit speeds. While the SNEs has fantastic hardware for sprites and its existing tile based layers, I've never heard of it having anytihng dedidicated to blitting (drawing) to bit planes so if the main processor of the SNES had to it it, it would likely be extremely slow.
The Amiga was specifically designed for fast blitting and planar graphics (full control of each bitplan independantly if desired)
But I suggest talking to an experienced SNES developer.
My guess is though you'd just be better off using the SNES's default hardware power as intended with I think up to 3 playfields whih would could independantly line scroll, and combined with some sprites, create the illusion of a great many layers of scrolling. You could also add in animated tiles to simulate other layers of scrolling.
@@bitbeamcannon2468 Yeah, it's up to four standard full-screen fully-overlapping layers that can all row/line scroll independently with varying colour depths depending on the background mode (four 2bpp layers with 24 visible colours per layer and 96 colours total for all backgrounds in Mode 0 for example), plus the standard up to 128 4bpp sprites with their own additional 120 visible colours as per usual (32 max sprites per scanline and 272 max sprite pixels per scanline). And there's some extra tricks that are possible by exploiting the high/low per-tile priority of each layer as well as the main/sub screens too for additional layering and parallax. So there's still plenty of scope there. But I was just curious about the bit-plane blitting thing as that sounded interesting too. Didn't think it would be an option on SNES to be honest, else I probably would have seen it mentioned elsewhere, but figured it was worth asking anyway just in case. :)
Superb for AMOS!
Thanks very much.
Very cool. Thanks for the video.
Thanks for watching!
So.... i just ran into the old Amos software in a box. Had high aspirations for it as a kid...but never dived into it
could you please tell me, how is the sky's background gradient effect achieved ( it is not a perfect gradient but rather it has some horizontal lines on it ) ? how is this retro technique called? thanks!
Hi,
The Amiga had a co-processor they called the copper chip which could do many things including change the RGB value of color indexes "during a vertical blanking gap" (basically each time the computer was done drawing each row of pixels and ready to move onto the next row of pixels to create the screen image).
In this way you could trick the Amiga to display things like gradients using only one color index, by changing the color it displays at any give full row of pixels.
AMOS has a "Rainbow" command which lets you control what RGB value any given color index displays at any vertical coordinate.
I created a separate too program in AMOS to analyze a guide image I made and reproduce the gradient (with horizontal lines and all) as AMOS compliant Rainbow instructions... in other words I made code in Amos which generates more code in Amos ;)
th-cam.com/video/VMADU2BVihY/w-d-xo.html&ab_channel=BitBeamCannon
@@bitbeamcannon2468 thanks a lot for your very fast and detailed response!
Amazing work. well done.
Thanks very much.
Ty for share , wish an nice day
Thanks very much for watching. We're glad you liked it!
Have you tried AMOS AGA?
Not yet. Our goal with the first few games is classic OCS.ECS compatibility. I think the progress being made on the AGA version of AMOS is awesome though, and I personally would love to eventually make an arcade style game which really shows off what AGA was really capable of, and in general I'm super glad the authoring systems are being developed and improved to empower people to make more and better games for Amiga.
-Mike
I had AMOS, but didn't have the compiler (too expensive). :(
Hello
Wow nice presentation. I have a question. I suppose you work also with Deluxe paint 4 or 5..and PPaint, why do you choose Brillance to draw ?
many thanks
I only used Brilliance in modern times to convert 256 color IFF images down to the proper IFF formats I needed for Amos. For making the pixel art in the first place I'd switched to Pro Motion NG on Windows based systems well over a decade ago.
Back in the day I had originally used Dpaint for a couple of years before getting Brilliance and I just liked the interface and tool-set of Brilliance more.
@@bitbeamcannon2468 Ha ok cool. Thanks for your info. Can I ask other detail ? I ´m creating a very simple game with Amos Pro on Amiga 600. THe game is like Sorcery from cpc (I´m sure you know it) The fact is when I create a iff with deluxe paint, with the default palette, then I create the bob with DP4 also.. After this I go to Amos edit object and grab the iff to convert as Bob, and when I load iff and load Abk one of them lose colors... If I use get bob palette bobis correct but the background color change, if I don´t use get bob palette then bob is Ko and background Ok.. I think it´s because I have to use the same colors in both but it´s already the case (default both)
What do you think ?
@@LuisDiaz-uu7xg They do indeed need to use the same exact color palette. Using the same colors is not enough, the colors must all be arranged in the same exact order in the palette, such as black for index zero etc.
@@bitbeamcannon2468 Wow ok, thanks for your help on this,I´ll try. have a nice week end
It's easy to do this in X68000 with knowledge of how the bitplanes work and the using the copper co-processor to do the pallette changes ( this is the hardware equivalent of the rainbow command) the copper co-processor only had about 3 intructions and was easy to learn. and it was never hard to achieve hardware horizontal scrolling on the amiga, the hardware was setup to do this.
i had a copy of this in early 90s. no documentation. i was like 13, didnt know how to use it but tried many public domain programs by typing them out of books or bulletin boards.
i did like logo and basic before that on c64 but man. i knew what this was. now 44, after 20 years as a tradie, the planets aligned and now im 1st year indy game dev.
i wonder if i can use something like this today, how would you run it not in an emulate but make it usable. can u run workbench from a webpage?
You have a few options, but I highly recommend looking into Scorpion engine by Erik Hogan, which let's you develop a real retro game once and with some additional effort, export that game to real Megadrive, Amiga, Neo Geo, and the CD versions of those systems. You can also "wrap" those exported games in an emulator so to the actual end-user/player it just seems like any other windows .exe
@@bitbeamcannon2468 😮 so i could technically do this and put it in my own cabinet? wow. i have all that im just working in ue5.4... thanks for that info
i use batocera and have used most of the frontend and emulators across the board. (pun intended)
currently running a custom batocera plus build so i can play KI1 and 2 etc.. but also gotta have kodi and a full GUI ( i use that neonflash one)
@@Ready_Fire_Aim Yes, absolutely you could use it in any emulator or real consoles and NeoGeo arcade cabinet systems as well.
Maybe the 16 colour sprite trick with all sprites side by side could be stamped into the background?
Not with Amos, as it does not support that at all... someone would have to completely replace the copper and sprite handling in Amos, likely with Assembly code for that, but with Scorpion Engine it's absolutely possible, but even with scorpion engine I think it's currently limited to using 3 color sprites for t he back layer. The great thing is though, due to Scorpion Engine's great use of the copper, you can have 4 totally unique colors per scan-line in the repeating sprite background and you can slice it up into segments which scroll at different speeds for some really AAA quality parallax effects. Have you seen our other project canned Aeon's Legend (AKA Scorpion Boy)?
@@bitbeamcannon2468 I'll check that out 👍
how much speed improvement could one get if done in assembler then?
A crazy amount, especially with a really strong programmer. Take a look at Metro Siege for example, which is a combination of C and Assembly, and runs great on OCS/ECS amigas.
This looks beautiful
Thanks very much. :)
Isnt that normal dual playfield? Basically the blitter lines up the bits and from back to front, which makes up the final image, as long as the opacity color is there, the copper shines through
No, this does not use normal dual playfield mode. this is a single 16 color layer, using the blitter to blit the background layer in on every screen update. This puts some strong color limitations on the back layer and some on the front, but allows for some of the foreground and all objects to be 16 color bobs instead of 7 maximum which would be the case for OCS/ECS dual playfield mode.
Amazing video. Do you have any info on your dev environment? I'm having a hard time setting up WinUAE, AMOS, etc.
Does this demo require AGA?
No, not at all. it runs well on a standard A500 for example. You can download the demo and load it in Amos professional etc.
bitbeamcannon.com/amiga/
Nice video thanks, I have a question, why don't the coppers / rainbows look like they would on a real system outside the left and right side of the viewing area? is it because of the emulator maybe? Or do you use something to prevent them from looking beyond the visible area? or it´s because just they appear in the indexed mapped colour assigned?
Some emulator settings are able to compensate for that, including by forcing a black border or making the low res screen take up the full screen instead of having a border, BUT the copper color changes only show up on the external borders of the screen if you are changing color zero, as you see in the video, I'm not changing color zero, so even on a real Amiga the borders stay nice and black. However, there was a programming trick that ECS Amiga's was capable of that could revert the color back to black on the edges, but I don't think AMOS was capable of that.
@@bitbeamcannon2468 Thanks Mike!.
@@AmitenTV You're very welcome.
The Agony trick is indeed very effective but the loss of half the color entries annoys me a lot. 😉
You could possibly increase slightly the blitting cost of he background bit plane to regain full use of the color entries. Instead of simply blitting the bob in your background bitplane (I assume it is bitplane 0 but it could really be any bitplane, the technique still works), you would have to AND it with an additional 1 bit mask plane. This mask plane would simply be the silhouette of the foreground elements. Thus, wherever the mask is 1 (meaning there is a foreground element), the blit operation would clear the background bitplane (or set it, depending on which convention was chosen) and thus prevent the background plane to influence the color index.
The added cost would be important but not enormous.
Essentially, instead of using two channels: source and destination, the blit would now use three: source, mask, destination. Thus adding only 50% to the total cost of the blit (x 1.5).
The mask can be constructed at the same time as he rest of the tiled background for a very small cost so mask construction is almost negligible.
If there are levels which are not too Blitter intensive but require more colors, this may be worth the extra cost.
Keep up the great work guys!
I forgot to mention that there is also a memory cost: the mask is the exact same size as the background image so this would double the background memory requirements.
Again, in some levels this may be an acceptable compromise.
Cheers!
thats looking great!
come vate fatto se il dualplay field ti limita solo a 8 colori e l'utilizzo di bob è lento da morì????'
Puoi scaricare il vero progetto Amos per questo dalla nostra pagina Amiga su bitbeamcannon.com/amiga/
Per assicurarci che potesse funzionare senza problemi con nemici ed effetti, ecc. abbiamo limitato gli aggiornamenti dello schermo (FPS) alla metà (quindi 25 per PAL e 30 per NTSC). Lo strato posteriore non è un doppio campo di gioco, utilizza una speciale modalità blitter per incollare un BOB a 2 colori sullo sfondo e il primo piano estremo è un altro schermo davanti allo schermo di gioco reale per il motivo dell'erba e gli sprite per gli alberi.
To make sure it could run smoothly with enemies and effects etc. we capped the screen updates (FPS) to half (so 25 for PAL and 30 for NTSC). The back layer is not dual playfield, it's using a special blitter mode to paste a 2 color BOB into the background, and the extreme foreground is another screen in front of the real playing screen for the grass pattern and sprites for the trees.
You can download the actual Amos project for this from our Amiga page at bitbeamcannon.com/amiga/
To make sure it could run smoothly with enemies and effects etc. we capped the screen updates (FPS) to half (so 25 for PAL and 30 for NTSC). The back layer is not dual playfield, it's using a special blitter mode to paste a 2 color BOB into the background, and the extreme foreground is another screen in front of the real playing screen for the grass pattern and sprites for the trees.
Can this trick be applicable in case of Dual Playfield?
you can use it in combination with dual playfield if that's what you mean, but since OCS/.ECS dual playfield is only 8 indexes per playfield it's a very big price to pay.
@@bitbeamcannon2468 So, one could use 2 colors for the fixed "BOB" background, 6 colors for the background playfield, 7 colors for the foreground playfield (that could be used exclusively for drawing enemies) and 16 colors for sprites, right?
@@ProfenixStudio Yes, BUT there is another severe color limit to the method, and that is, anywhere the BOB simulated back layer is drawn, you can't use half of the available colors in that portion of the layer or it will ruin the effect. I can't remember if it's the odd or even indexes you can't use, but only every other color index will properly seem opaque over the simulated back layer made with the special bob.
@@bitbeamcannon2468 you mean all the colors of the dual playfield or only the colors of the background playfield (where I draw the bob)? In other words, as in agony, in that portion I use one of the 3 bitplanes available for the background playfield, right?
@@ProfenixStudio The colors of the back playfield. The front playfiend would not be effected in any way.
This is awesome.
Thanks very much!
Is the video recorded from original Amiga or emulator?
Emulator, but it was also tested on a Real Amiga.
How many enemies are yuu planning to add3
I don't plan on building on top of this engine at the time. I made it public and open-source in hopes the community will build on top of it, optimize it, and continue to share it with others. I am and will be working on additional tools and examples. Have you watched our 'rainbow ripper tool' video yet?
Wait this’ll run on A500? 🤯
Yup. Made in Amos.. it runs smoothly at 25 FPS if I recall... It could likely run at 50/60 FPS if codded in Assembly
This game was written in Amos ?!!!
The games written in Amos I remember were always some low budget, really cheesy, bad looking shootem ups :D !
With so many image generative AIs you can generate beautiful background for your games for free and create a fantastic game for Amiga.
AMazing times !
This demo was made with Amos, and I had also made a SHMUP demo in AMOS, but the real DaemonClaw is currently not yet being developed for Amiga, BUT when it is made for Amiga we'll be using the same code base (and programmer) who's currently working with us to make Metro Siege, but the engine will be enhanced to support AGA specific hardware etc for DaemonClaw
wish they'd release AMOS for windows PCs!! that would be awesome!
There are ongoing efforts by different people and groups to make branch versions of Amos for full AGA support, editor/UI improvements, and making a windows executable that automatically opens Amos Pro on your PC in an emulated Amiga environment.
Aside from that, if you don't care so much about specific ties to Amiga specifically (or Amos), there are incredible and easy to learn authoring systems out there ranging from Construct3 to Unreal Engine.
I remember there had been people trying to make a literal port of Amos Basic to work and run and export for modern systems, but I'm not sure if they are still working on it, succeeded, or if it's abandonware.
-Mike
I wish I had seen this 30 Y ago lol
Where’s all the love for Blitz Basic? In my experience Amos was slower than Blitz Basic. Maybe later versions of Amos improved performance? Note that the last time I touched either one was in the early nineties.
Gorgeous pixel art BTW.
Thanks very much. Blitz is awesome but it was just all a matter of timing and convenience for me. I had already learned and began projects with Amos back then before I became aware of Blitz Basic. In other words, I greatly respect Blitz, but I'm not the right person to make any videos or tutorials about it.
AMOS had already garnered a massive following by the time Blitz was released.
is it ecs or aga?
OCS/ECS, but it would work the same if you used it on an AGA system. It should also be compatible with higher color-count AGA modes, but I've never tested it with any AGA extensions on AMOS,
I'm very familiar with the Amiga hardware, especially the gfx ASIC. I used to dabble with AMOS back in the day too. However I could not follow this video AT ALL. INDEXES? You sound like PC programmers. They're not tables, they're not indexes, they're color registers. I hate having to stop and mentally reconfigure. The multiple bitplanes are fetched word at a time, then each word is essentially shifted (I assume it's a rightshift), with the output bits select which color register is allowed to gate out three 4-bit groups (12 bit color for the OCS) to the color DACs. Now if you want to call than an index??? OK but that's really confusing. I'm old and cranky, I know.
Did you ever really explain how the diddled plane does not affect color register selection? The only thing I can guess in that that you blit the mountain stuff *first* each time, then manually blit the other stuff atop it (and the sprites always do their automagic spritely business). We have to assume this because you never mention masking or playfields in any useful detail AFAIK. Or I missed something!
The mountain is actually blitted after the foreground is (right on top of it all) but before any characters or items, but because the the special blit setting telling it to only blit certain bit-planes, the mountain art doesn't effect the specific color registers that are used in that part of the foreground art.
BTW, I picked up the terminology color indexes as a pixel artist, and not a PC programmer. I grew up with first an Adam Computer, them a C64, then Amigas, then finally Windows based PC.
-cheers
Mike
Written in AMOS? how? looks far too good to be made in it?????
Thanks. You can download the actual Amos project here: bitbeamcannon.com/amiga/
You can reuse the code however you'd like, but no one can use these graphics, so please replace them if you want to make your own game or demo.
Nice "trick", but you have to say that It's unusable for a real game, because you can't draw an evolving background, only the same screen running in a loop. That's the difference between real scrolling playground, which is quite impossible to make in Amos, and an nice but useless "screen offset" like this one...
Thanks for taking the time to comment, but how do you propose this wouldn't work in a real game? The foreground could be any kind of robust evolving tile map, and regarding the background being static, I wouldn't call that a 'cheat', but a compromise to get get a parallax effect within what is possible in AMOS. Mountains in the far distance actually would appear static unless you traveled very far horizontally in a level, so that only poses a problem if you want a different type of background like a stone wall that's also close to the player, in which case the repeating sprite trick (which AMOS can't do) would be a far better method for achieving that kind of parallax on OCS/ECS Amiga.
@@bitbeamcannon2468 For the foreground (the forest), you open a 572-pixel-wide screen, within which you scroll using a "screen offset" function, that is fast because it change only the coper positioning of view in the memory. But to make a game with a real level design made up of dozens of screens to scroll through, you can't open a screen thousands of pixels wide, in particular with the 512Ko Chip Ram of the A500. This kind of scrolling use blitter operations, and it's not possible in Amos.
To be perfectly honest, it's possible to do this kind of scrolling with a simple "screen offset", and a single screen twice the size of the screen, as some shoot 'em ups do, but it's rather limited in terms of scrolling possibilities. The idea is to prepare the playing field on the non-visible part of the screen on the left, little by little as the player moves to the right, copying next vertical offset lines as he goes on right, then returning to the first half of the screen in one go when the player reaches the far right. But this technique dont let you move in two directions (or more), and is also very difficult to do in AMOS.
@@plopparici3110 The next step of the demo was going to be to try to make it work using an actual tile map scrolling routine, but we had to move onto other things before we could try. Indeed AMOS forces lots of limitations on the programmer and on performance than the Amiga hardware was capible of.
when programming was artesanal....
When spelling was artisanal.
Art is anal
PLEASE PLEASE PLEASE..... I beg you.. Make the Game FULL SCREEN and not cut off at the top to place the score there (The HUD?).... Add the SCORE and ENERGY later right ONTOP of the Action at the top like some of the other versions you've done. The background should fill the entire visible screen of a CRT TV... Pretend this is for an arcade. If possible make it Overscan so there are not visible black borders on any of the edges. This always screams professionalism, plus will look better in Emulators in the future.
And by Golly...use EHB/Extra Half Brite mode for 64 colors...... you can do more if you do the Broadcast Titler 2.0 trick of layering different Public screens as one, giving you double or triple or quadrule the colors. Or at least look at ElfMania and Ruff N Tumble...the color use is superb and both are 64 colors.
KUDOS for Using Brilliance.... Better than DPaint... But I suggest HIGHLY you use Brilliance 2.0 as it was greatly improved over Brilliance
Have you seen the game lately? It should make you happy: bitbeamcannon.com/daemonclaw/