Arcade Marquee Collaboration?
Arcade Marquee Collaboration?
hey there, I'm the creator of a line of dynamic LED and LCD marquees that change to match the current game called Pixelcade, http://pixelcade.org. If there is any interest is doing an integration with MiSTer, do let me know and we can explore.
Thanks,
Al
Thanks,
Al
- LamerDeluxe
- Top Contributor
- Posts: 1262
- Joined: Sun May 24, 2020 10:25 pm
- Has thanked: 918 times
- Been thanked: 303 times
Re: Arcade Marquee Collaboration?
I'd expect lots of people who have MiSTer powered arcade cabinets to be interested in this.
- redsteakraw
- Posts: 245
- Joined: Sun May 24, 2020 11:19 pm
- Has thanked: 1 time
- Been thanked: 41 times
Re: Arcade Marquee Collaboration?
There may be some interest, you should talk to porkchop / mister addons, he has a storefront and will be selling JAMMA IO boards this would make a nice bundle. Is any of the controller software open source so it can be integrated into the project? https://twitter.com/MisterAddons
Fear is the mind killer!
Re: Arcade Marquee Collaboration?
thanks much, I'll do that. Parts of Pixelcade are open source, yes. The easiest way to integrate though would be through the Pixelcade API http://pixelcade.org/api but this assumes MiSTer can make REST API calls. I am a newbie to MiSTer so not sure if that is a possibility or not. Anyhow, will look into further and thanks for the guidance.
-
- Core Developer
- Posts: 300
- Joined: Sun May 24, 2020 6:55 pm
- Has thanked: 5 times
- Been thanked: 154 times
Re: Arcade Marquee Collaboration?
When a new arcade game (or core starts) we need to hit the rest API with some kind of identifier to switch the marquee?alinke wrote: ↑Thu Feb 11, 2021 7:44 am thanks much, I'll do that. Parts of Pixelcade are open source, yes. The easiest way to integrate though would be through the Pixelcade API http://pixelcade.org/api but this assumes MiSTer can make REST API calls. I am a newbie to MiSTer so not sure if that is a possibility or not. Anyhow, will look into further and thanks for the guidance.
How do we know where the API lives? Or is it the java app running on MiSTer? I am not sure it would be a great idea to run the java app on a mister, we could try it though.
Re: Arcade Marquee Collaboration?
thanks for the reply. yes, that's correct, pass the rom name to Pixelcade's API and then it'll change. And you're correct, the API is part of the java console app that would run as a daemon on the MiSTer. It's a pretty low profile Java console app/ no GUI and have it running on pretty low powered hardware but I'm also not familiar with the MiSTer architecture. The .jar itself is around 20 MB, JRE is 100 MB or so, and then a matter of how much of the artwork to load. The artwork is 128x32 PNG file per game so doesn't take much space. And then the Pixelcade hardware itself would connect via USB and would need to be recognized by the OS as a virtual serial port device (ex. /dev/ttyACM0) for the LED version of Pixelcade or for the LCD version of Pixelcade, no USB is needed and instead it would just make a REST API call over WiFi to the LCD which has its own single board computer. Let me know what you think, thanks again.
Re: Arcade Marquee Collaboration?
Mister writes the current corename/setname to /tmp/CORENAME. You could probably just watch for changes in that file via the linux inotify API or use the command line /bin/inotifywait command to do it in a shell script. For arcade games that file will usually contain the rom name (assuming the MRA has the setname correctly set).
This should be doable with zero changes to Mister code
edit: NEOGEO is going to be a problem since it doesn't change the core name like arcade MRAs do
This should be doable with zero changes to Mister code
edit: NEOGEO is going to be a problem since it doesn't change the core name like arcade MRAs do
- venice
- Top Contributor
- Posts: 789
- Joined: Tue Jun 16, 2020 9:29 am
- Location: Germany
- Has thanked: 285 times
- Been thanked: 281 times
Re: Arcade Marquee Collaboration?
I can't confim this as i found NEOGEO written in /tmp/CORENAME.
Or am I missing the point?
Re: Arcade Marquee Collaboration?
You'll never get the actual game names in /tmp/CORENAME, is what I meant. So you can't determine if say, metal slug is being played, only that NEOGEO is the current core.
-
- Posts: 5
- Joined: Sat May 30, 2020 12:01 pm
- Has thanked: 2 times
Re: Arcade Marquee Collaboration?
I am currently trying to use inotifywait to see which rom is loaded by a core on the linux side. This is generally working fine, but shows a strange effect I described here: https://misterfpga.org/viewtopic.php?f=27&t=2058.
I have not looked at Pixelcade in deep yet, but I think one possible scenario avoiding running the Pixelcade application would be a shell script on the MiSTer side, reading core/rom information via /tmp/CORENAME and inotifywait and then acessing the pixelcade HTTP/REST API (via curl) running on a separete pi (zero, if cost is an issue) which in turn controls pixelcade. This would mean minor modifications on MiSTer side and very few additional computing overhead.
EDIT: added curl for the REST API call to clarify that I wanted to avoid running the pixelcade application
EDIT 2: Issue was solved, I can continue with my inotify experiments.
I have not looked at Pixelcade in deep yet, but I think one possible scenario avoiding running the Pixelcade application would be a shell script on the MiSTer side, reading core/rom information via /tmp/CORENAME and inotifywait and then acessing the pixelcade HTTP/REST API (via curl) running on a separete pi (zero, if cost is an issue) which in turn controls pixelcade. This would mean minor modifications on MiSTer side and very few additional computing overhead.
EDIT: added curl for the REST API call to clarify that I wanted to avoid running the pixelcade application
EDIT 2: Issue was solved, I can continue with my inotify experiments.
Re: Arcade Marquee Collaboration?
One thing to be aware of: a lot of the rom packs people are using do not separate every rom into a single zip file. The roms are in one huge zip file. MiSTer is agnostic to how you package roms, so there are basically infinite possibilities and naming. Without actual changes to Main_Mister you're going to be blind to the actual name of games selected rom inside of zip files
Re: Arcade Marquee Collaboration?
the setname gets written to /tmp/CORENAME for arcade games, so those are covered fairly easily. If they're trying to figure out which rom was loaded for consoles that's a huge mess of rom packaging on the internet...
Re: Arcade Marquee Collaboration?
Pixelcade has two flavors, for the LED version, MiSTER would need to run the console java app locally. For the LCD version of Pixelcade, there is a separate Orange Pi that drives the LCD that accepts the REST API calls so on LCD, your suggestion would work as is. That said, the Java console app is pretty lightweight and should not cause a performance issue unless MiSTER is very sensitive there (I'm a MiSTER newbie so don't know the underlyings there). Thanks for the suggestions , this is all very helpful. I'll report back my findings after my board comes in.NegentropicMan wrote: ↑Mon Feb 15, 2021 9:18 pm I am currently trying to use inotifywait to see which rom is loaded by a core on the linux side. This is generally working fine, but shows a strange effect I described here: https://misterfpga.org/viewtopic.php?f=27&t=2058.
I have not looked at Pixelcade in deep yet, but I think one possible scenario avoiding running the Pixelcade application would be a shell script on the MiSTer side, reading core/rom information via /tmp/CORENAME and inotifywait and then acessing the pixelcade HTTP/REST API (via curl) running on a separete pi (zero, if cost is an issue) which in turn controls pixelcade. This would mean minor modifications on MiSTer side and very few additional computing overhead.
EDIT: added curl for the REST API call to clarify that I wanted to avoid running the pixelcade application
EDIT 2: Issue was solved, I can continue with my inotify experiments.
Re: Arcade Marquee Collaboration?
that's good to know and would be an issue as Pixelcade does need the ROM name of the current game in order to work. I'll play around with it and report back what I find as soon as my hardware comes in, thanks for the help!zakk4223 wrote: ↑Mon Feb 15, 2021 9:46 pm One thing to be aware of: a lot of the rom packs people are using do not separate every rom into a single zip file. The roms are in one huge zip file. MiSTer is agnostic to how you package roms, so there are basically infinite possibilities and naming. Without actual changes to Main_Mister you're going to be blind to the actual name of games selected rom inside of zip files
- venice
- Top Contributor
- Posts: 789
- Joined: Tue Jun 16, 2020 9:29 am
- Location: Germany
- Has thanked: 285 times
- Been thanked: 281 times
Re: Arcade Marquee Collaboration?
I have something similar running using zakk4223's "inotifywait" Idea in a script.
The display is just a bit smallerdata:image/s3,"s3://crabby-images/9d6e9/9d6e939f03901fe7cf0901b052b8f73e4e259d56" alt="Very Happy :D"
https://misterfpga.org/viewtopic.php?f=9&t=1887
The display is just a bit smaller
data:image/s3,"s3://crabby-images/9d6e9/9d6e939f03901fe7cf0901b052b8f73e4e259d56" alt="Very Happy :D"
https://misterfpga.org/viewtopic.php?f=9&t=1887
Re: Arcade Marquee Collaboration?
small but might! very nice, looks like you've got the console marquee artwrok, were you able to get game names also?venice wrote: ↑Sun Feb 21, 2021 5:48 pm I have something similar running using zakk4223's "inotifywait" Idea in a script.
The display is just a bit smaller
https://misterfpga.org/viewtopic.php?f=9&t=1887
- venice
- Top Contributor
- Posts: 789
- Joined: Tue Jun 16, 2020 9:29 am
- Location: Germany
- Has thanked: 285 times
- Been thanked: 281 times
Re: Arcade Marquee Collaboration?
...not really.
Most times you need to translate a bit the content of /temp/CORENAME (mooncrgx = Moon Cresta, tgfx16 = TurboGrafX16).
But as stated in some comments before Arcades are OK.
Games running on Computers or Consoles are actually not to identify, as I understand it.
Re: Arcade Marquee Collaboration?
Hey All, thanks for all the advice and guidance here. We ended up getting this working and have MiSTer support for both the Pixelcade LED and LCD line of marquees. Here's a video of it in action https://youtu.be/hhrPBrxSyRQ .
My partner who did the actual MiSTer integration also designed a pretty cool case for MiSTer which you'll see in that video too.
Welcome any feedback.
My partner who did the actual MiSTer integration also designed a pretty cool case for MiSTer which you'll see in that video too.
Welcome any feedback.
- venice
- Top Contributor
- Posts: 789
- Joined: Tue Jun 16, 2020 9:29 am
- Location: Germany
- Has thanked: 285 times
- Been thanked: 281 times
Re: Arcade Marquee Collaboration?
Very very coolalinke wrote: ↑Wed Jun 23, 2021 12:54 am Hey All, thanks for all the advice and guidance here. We ended up getting this working and have MiSTer support for both the Pixelcade LED and LCD line of marquees. Here's a video of it in action https://youtu.be/hhrPBrxSyRQ .
My partner who did the actual MiSTer integration also designed a pretty cool case for MiSTer which you'll see in that video too.
Welcome any feedback.
data:image/s3,"s3://crabby-images/9d6e9/9d6e939f03901fe7cf0901b052b8f73e4e259d56" alt="Very Happy :D"
How did you get the Core/Game information out of the MiSTer Menu?
PM me if you like.
Re: Arcade Marquee Collaboration?
thanks, it turned out to be a combination of a small MiSTer mod (will post a GitHub link to the change a bit later) and then monitoring these files. With those in hand, the mod then makes a call to the Pixelcade REST API http://pixelcade.org/api to update the marquee.
/root# more /tmp/FULLPATH
_Arcade/_Organized/_2 Core/_Capcom - Black Tiger
/root# more /tmp/CURRENTPATH
Black Tiger
/root# more /tmp/CORENAME
NEOGEO
/root# more /tmp/FULLPATH
_Arcade/_Organized/_2 Core/_Capcom - Black Tiger
/root# more /tmp/CURRENTPATH
Black Tiger
/root# more /tmp/CORENAME
NEOGEO
Re: Arcade Marquee Collaboration?
...specifically, it is a small "5-liner" patch in menu.cpp that does this. The code is in my fork, here: https://github.com/kaicherry/Main_MiSTer
Hidata:image/s3,"s3://crabby-images/1e0c3/1e0c3cf0e740e2e73ac2f0e6307acce0536c51c1" alt="Smile :)"
Hi
data:image/s3,"s3://crabby-images/1e0c3/1e0c3cf0e740e2e73ac2f0e6307acce0536c51c1" alt="Smile :)"
Re: Arcade Marquee Collaboration?
To be clear, that link is to the API docs. The software doesn't make outbound calls to the internet for any purposealinke wrote: ↑Wed Jun 23, 2021 8:04 am ...then makes a call to the Pixelcade REST API http://pixelcade.org/api to update the marquee.
data:image/s3,"s3://crabby-images/1e0c3/1e0c3cf0e740e2e73ac2f0e6307acce0536c51c1" alt="Smile :)"
-K
Re: Arcade Marquee Collaboration?
looks like a recent release broke things here, really what needs to happen to keep the Pixelcade integration working with MiSTer is that this PR gets accepted https://github.com/MiSTer-devel/Main_MiSTer/pull/416 . The only thing this change does is add the select game to /tmp/FULLPATH which Pixelcade then picks up so we know what game marquee to display. If anyone has any influence over a developer who can accept this PR, that would be much appreciated. Thanks much
Re: Arcade Marquee Collaboration?
Update, massive, big thanks to @sorgelig for making the code mod needed for Pixelcade marquees to work with MiSTer , now in the main code base https://pixelcade.org/mister/