Show Control Panel Layout before game starts in RetroPie, just like Arcade1UP does.
-
@Texacate hi I wouldn’t interpret the lack of downloads for lack of interest! While I feel pretty good navigating pi menus and doing what I am told and stuff, I still have no idea how to pull scripts off of github and use/test them. If you work is now where I can use it to try to generate the images for my games I am happy to try and test it. But - what do I need to do? I would be generating the images to try to use them as launching images on my personal setup.
1-It sounds like after I downloaded the script (this I don’t know how to do) I would run it from command line (assuming I would say sudo (path to script? Where would it go after download?)
2- and it looks like from your documentation I would add at the end the rom name then the image would be generated in my arcade Roms folder for use. Right?
3- I don’t know if there is some way it would just read for .zip files in my arcade folder otherwise and then create the images for whatever games it can or if it has to be done on a game by game basis.
4-Also, I saw it will pull game logos into the image but is that art pulled from within a “wheel” folder that is inside the arcade Roms folder? Sorry for all the questions.
-
@BJRetro I really need to fill out the download/usage sections of the documentation. There are some dependencies there. Tonight after work, I'll work on that. But let me try to briefy answer your questions.
Q1) Yes, that is the general idea. You would run it from command line. Using sudo should not be necessary to download the scripts and build images, but it may be needed to install ImageMagic. I'm actually building images on my Mac. Haven't actually tried to build images on the RPi yet. But I can't think of a reason why that wouldn't work. Again, I still need to separate all the image-display stuff from the image-create stuff.
UPDATE: Added support to build images on the RPi if desired.Q2) That is correct: From the terminal: "button_map.sh paceman" (don't use the.zip extension, just the basename). It will it generate the image in "a" folder named "./arcade", but I don't recommend that be THE arcade folder where your roms are... Yikes. I should change the generation folder name! You'll probably want the generated image to live somewhere else. That will completely depend on how one uses the images. Let me give that problem more thought. I build the images in a completely separate "sand-box" area. And if they look okay, I move them where they need to live.
Q3) It could be enhanced to do this. For now, you could list your rom directory to a file, and edit that file into a script that calls button_map.sh over and over again (remember to strip of the .zip extension). I may write separate, more elegant way to do what you are asking. The workaround I just suggested is pretty crude, but it gets the job done.
UPDATE: Added new script that does exactly this:for_all_roms.sh
Q4) Yes. The wheel folder is usually kept inside the system folder for ES and AttractMode themes that use wheel art. I only pull from this folder, so it is safe to point the button_map.sh script to the ~/RetroPie/roms/arcade/wheel folder. There is variable at the top of the script to for the pathname to the logo/wheel-art folder.
-
Re: building images for parent roms and/or clone roms...
Let's say you want to build an image for a clone rom, but the button label data is only available for the parent rom:Last night I prototyped a way to do that. I was able to build significantly more button map images for the set of roms currently in my cabinet. But it also added an additional level of complexity to the database searching issues I already have... :-(
I definitely need to get proficient in XML searching... I'm a noob in that area. Ah, well. One more skill to acquire, right? -
@markwkidd In your controls archiving project...
- How are you managing the parent / clones control data? Are you just archiving the parent ?
- Similarly, how are you managing the different (but related) parents that have identical control information ?
The StreetFighter and KingOfFighter series are examples of this. If it's easier to point to a GitHub URL, just send me the link. I can go see for myself.
-
@Texacate have a look here mame2003-plus/controls.c
Maybe this wiki is interesting for you adding button names
-
@Texacate said in Show Control Panel Layout before game starts in RetroPie, just like Arcade1UP does.:
How are you managing the parent / clones control data? Are you just archiving the parent ?
Similarly, how are you managing the different (but related) parents that have identical control information ?As @robertvb83 mentioned and is described in detail in the MAME 2003-Plus developer docs that are linked there, the mapping between the control names happens elsewhere, in the driver source.
This can also be grepped/scripted easily because there are macro names (the
GAMEC
macros, etc) that can be used as tokens for finding the mappings. -
@robertvb83 Most excellent! As a "User" contributor, the only thing I didn't see on that Wiki page was how to best get the info to the lr2003plus team. (email to someone, a forum post somewhere, a github issue...) And I assume if the parent of ROM isn't already mentioned controls.c, those would be the one(s) you are most interested in. Correct? I'll do my best to contribute using the format in the wiki. Ive gone through a bunch of games on my cabinet, and added new button labels. ~50 so far, only 800 to go, LOL
-
@Texacate hey thanks thats a good point with contact information. I cannot change this myself but i think @markwkidd can add that info/links.
The button names for retroarch are great especially for unusual joypad layouts. So i already contributed some exotic games like stonebal or space wars. With written functions instead of btn1 btn2 btn3 it is now much easier to configure those games for any joypad that people use.
Of course missing clones are always welcome or even missing parent roms. But be aware not always are clones the same as parent by means of button names
Would be super cool if your naming contributions find their way into mame2003-plus as well
-
Kinda circled around back to this. You all are doing more with this than I can. This is a mock up of what I originally was going for:
And keep in mind this is tailored to my tastes and nothing is automatically built...everything is manual.
However, my goal was to get to where the background, control panel, marquee, ect. were in a separate folder for either a system or game and then have a XML setting file to assemble the file based on what files were supplied. Would work on once part at a time.
After looking at what you are all doing...may be making this a bit to complex. Will be trying out Texacate's example this weekend to see if I can get that up and running.
-
Cool. I love your concept example! Maybe someday. BTW, I just put my latest script, plus the CSV files, on GitHub. It's not very polished yet. But much better than previous versions.
- I added support to run the main image creation script
button_map.sh
on the RPi. - Updated the Wiki on installing ImageMagick on the RPi.
- If button data for a clone is not available, the script will attempt to use the button data from the parent rom.
- Generates a place holder image, when no button data is available. Leaves them in the the tmp directory.
- Uploaded a separate file with my suggested button data for additional roms. I have about 250 roms listed in
custom_map.csv
so far. More to come, I play a dozen or so games every day, and try to figure out what the appropriate names are for the buttons. I do try to look for a picture of the original arcade cabinet, and use those labels if possible. - Added a new script for doing your entire collection, all at once.
for_all_roms.sh
I'm amazed how many games are just vertical shooters, with the exact same Fire,SuperBomb buttons. I found a fun unique variation on that theme. Check out dfeveron.zip and its Disco Bomb!
- I added support to run the main image creation script
-
@Texacate Thanks...I plan on installing it this weekend. I have been looking at ImageMagick and messing around with it as well. Will let you know how your install goes.
-
@TheRealSmilebit
custom_map.csv
contains 600 labels now! Getting the data from www.arcade-museum.com, but its not automated. Clicking on each game's web page, and copy/paste . Not all pages have labels, but it's been much faster than playing each game. Downside is, there's a chance I don't have the buttons in the right order. Verification will be needed at some point. -
Update: I have collected button label data for ~1000 games, plus the ~1000 from the the controls.dat project, for a total of ~2000 titles. For now I'm done collecting the button data, and will work on improving usability of the image generation script. Suggestions are welcome.
-
I received some feedback and have flipped how the two rows are labeled by default;
New Mapping
MAME RetroPad CntrPnl 123 --> YXL --> 123 456 --> BAR --> 456
Before it was
MAME RetroPad CntrPnl 456 --> YXL --> 123 123 --> BAR --> 456
Also, the script searches three database files for label data, (vs one previously). Now:
custom_map.csv
file is truly reserved for user customizations,button_map.csv
file was renamedprimary_map.csv
, and the additional data I collected is insecondary_map.csv
-
@Texacate Thanks a lot for this project! I plan to use it on a secondary SPI LCD connected to the GPIO. I assume that in this case I need to modfiy the server so that it outputs the images in a second framebuffer, rather than a second Raspberry.
Regarding the mappings, could this be made configurable via an external file? The motivation is that, whereas Mame-2003plus default mapping is:
123
456In FBalpha (which I use more often for arcade games) it is:
456
123Also, with this approach it could be possible to support global custom controls.
-
@janderclander14 said in Show Control Panel Layout before game starts in RetroPie, just like Arcade1UP does.:
@Texacate Thanks a lot for this project! I plan to use it on a secondary SPI LCD connected to the GPIO. I assume that in this case I need to modfiy the server so that it outputs the images in a second framebuffer, rather than a second Raspberry.
Yes. Discard the simpleClient.py file completely, and strip out all the socket communication code from simpleServer.py, and only keep the bits that reassembles a full pathname of the desired image from the system name & rom name, and displays it. By the way, the whole reason I chose python for that part was I found a good tutorial on client/server communication. If I was coding it to work all on a single RPi, then the file-display stuff would have been written in bash.
Could (the mapping) be made configurable via an external file?
( Mame)
123
456In FBalpha (which I use more often for arcade games) it is:
456
123Yes, button_map.sh could certainly be enhanced to read an external config file. But assuming the number of different configs is small and predictable, it might be easier to pre-code the required mappings, and just add a switch to select the one you want. Something like: if ($arg2 = "-fba") use 456123, else use 123456.
Also, with this approach it could be possible to support global custom controls.
I'm not sure I understand what you mean by global custom controls. Are you thinking of something beyond button labels? As in; joystick direction labeling, trackballs active/inactive, different control panel arrangements, etc.
-
Also a the RPi (out of the box) has only one frame buffer. This is baked right into Raspian. I did some google research on adding a second frame buffer. There are some success stories out there, but as I recall, details were sketchy and the whole thing seemed pretty advanced. That was another reason I chose a second RPI. If you find the solution, please post! I gave up, and spent an extra $30 on another RPi.
-
@janderclander14 said in Show Control Panel Layout before game starts in RetroPie, just like Arcade1UP does.:
In FBalpha (which I use more often for arcade games) it is:
456
123I use that arrangement too. I've updated the script to handle it. Try the latest version on github, and append the switch"-fba" to the command line. Default is still:
123
456But
button_map.sh <game> -fba
gives you:
456
123Also added
button_map.sh <game> -8btn
which gives you:
1237
4568 -
@Texacate Thanks a lot! This adds quite a lot of flexibility across emulators and control layouts.
Regarding the frame buffer, the RPi only supports two framebuffers if the second one corresponds to a LCD screen connected to the GPIO via SPI. These are usually small screens that plug like a HAT and that, because of the serial connection, offer poor refresh rates. However, they are fine for displaying static images like the panel layout or the marquee.
Here you can see the build of a user that employed one of these small screens to display the title of the game in a snes cartridge while using the HDMI output as the main display:
https://retropie.org.uk/forum/topic/3376/pi-in-a-super-famicom-build
He also provides a runcommand script to detect the running game and display the artwork, similarly to your project.
As far as using two framebuffers in general, for example, combining the HDMI and DSI outputs, I'm only aware of a beta kernel that seems to support this but does not seem to be included in the public distribution yet:
-
@janderclander14
Thanks for the pointers! I noticed that post #177 of the Super Famicom project included the runcommand_onstart.sh code, to display the image on the SPI based LCD. Very cool. I'd say go with that versus what's in my simpleServer.py script. It seems to follow very similar "fall-back rules" when the desired image isn't found.Let us know how your build goes! Do let me know if you find errors in the primary and secondary database files. The secondary one especially was a whole lot of copy-n-paste.
Contributions to the project are always appreciated, so if you would like to support us with a donation you can do so here.
Hosting provided by Mythic-Beasts. See the Hosting Information page for more information.