A Pixelcade Listener called pixelweb (Windows and Linux) runs in the background and listens for REST URL calls. Note these are local REST calls to localhost so an Internet connection is not required. However if your host is reachable via the Internet, then you can make these calls remote too. 

API Support for Pixelcade LED and Pixelcade LCD

All V1 REST APIs will function on Pixelcade LED. For Pixelcade LCD, the following V1 API limitations apply and also note the additional V2 APIs below that only apply to LCD.

  • Substitute pixelcadedx-xxxxxxxx.local for localhost for all API calls where xxxxxxxx is a unique ID for each Pixelcade LCD
  • Loop commands and the Queue feature will not work with LCD so just omit the loop parameter when using the API with LCD.
  • Animations are not supported
  • Scrolling text is supported but will continuously loop until the next API call is received. Font size, speed, number of lines, and offset are not supported.
  • localplayback is not supported
  • quit, reboot, and shutdown are supported
  • Only streaming, no writes
  • Add the URL param &ledonly if you want the command to only display on Pixelcade LED and not be relayed to Pixelcade LCD

V1 REST API

The Pixelcade Listener is launched via pixelweb.exe on Windows and pixelweb on Linux. Note that Pixelcade LCD using pixelweb.jar. Use the -silent parameter to launch pixelweb without console messages.

Note be sure you have the latest version of the Pixelcade software to guarantee all of the below APIs are included. All the examples below refer to localhost but you may also use the ip address or dns name. For example, http://pixelcade.host:8080 or http://192.168.1.206:8080)

REST CallResult
http://localhost:8080/arcade/[stream or write/[console name]/[rom name]

Displays a console/emulator specific PNG or GIF. If the console specific PNG or GIF does not exist, displays the default marquee or displaying scrolling text if ?t=[alt-scrolling-text] was specified.

Stream or write a PNG (still image) or GIF animation to the LED marquee. In write mode, the PNG or GIF will continue to display after the Pixelcade listener has been shutdown. Write includes a physical write to the microSD card on the PIXEL board and then the PNG or GIF is playing back locally with no dependency on the PC or Pi. With stream mode , the Pixelcade listener must be running. Stream mode playback is instant while there is a delay with write.

Note that write is only available in the legacy Pixelcade version at this time.

Additional URL params

?nogif – Only display a PNG if there is also a matching GIF

?gifonly – Only display a GIF if there is also a matching PNG

Note if both a PNG and a GIF exist for the same game, the GIF will play first and then the PNG.

Some games have multiple GIFs (the LED art pack adds more multiple GIFs) like for example:

qbert_01.gif

qbert_02.gif

qbert_03.gif

If there is a multiple GIF as defined by the naming convention game_0x.gif, then Pixelcade will pick one of them at random per each API call and then land on the game PNG (ex. qbert.png).

Path of the default marquee which can be changed by the user: <pixelcade home folder>/console/default-marquee.png

http://localhost:8080/console/stream/[console-name]?t=[alt-scrolling-text]

Displays a console/emulator specific PNG or GIF. If the console specific PNG or GIF does not exist, displays the default marquee or displaying scrolling text if ?t=[alt-scrolling-text] was specified

The same optional text parameters (font, size, lines, yoffset, etc.) can be used here too.

http://localhost:8080/quitShuts down the Pixelcade listener
http://localhost:8080/rebootRaspberry Pi or Pixelcade LCD: Reboots the OS
http://localhost:8080/shutdownRaspberry Pi or Pixelcade LCD: Shuts down the OS
http://localhost:8080/localplaybackPuts Pixelcade into local playback mode meaning it will play the last png or gif that was written to it’s microSD card
http://localhost:8080/arcade/stream/black/dummyBlanks out the LED marquee
http://localhost:8080/text?t=<Your%20Scrolling%20Text%20Here>Send scrolling text. Make sure to add %20 for all spaces.
http://localhost:8080/text?t=[scrolling-text]&c=[color]&s=[speed]&font=[font name]&size=[font size]&lines=[number of lines]&yoffset=[offset number]&loop=[number of times to loop scrolling text]

?t=[your text] is required, the rest of the parameters are optional. ?t=hello world will scroll the text “Hello World”

&c=[color] changes the scrolling text color. Possibles values are: red, blue, cyan, gray, darkgray, green, lightgray, magenta, orange, yellow, pink, and white. &c=green or &color=green will change the text to green.

Hex color values may also be entered in 6 digit format without the # sign. &c=45B39D for example

For scrolling speed, smaller number means faster scrolling. Range 10 – 150. &s=10 for example

The color will default to red if no color is specified or if an invalid color is specified. Of if a color is not specified and random is specified as the default color in settings.ini, then a random color will be used.

New TTF (TrueType) fonts can be added to the /fonts folder. Specify the TTF font name, not the file name. Example font names are “Handwriting”, “Tall Films Fine”, and “Haunting Attraction”. The default font is “Arial Narrow 7”.

Font size ranges are typically 14 – 32. &size=20 would change the font size to 20. Default font size is 28.

lines can be 1, 2, or 4. &lines=4 would change to 4 lines of text. If 2 or 4 is selected, the font and font size will be over-riden.

As some fonts will not center vertically correctly, the yoffset parameter can be used to adjust. &yoffset=-4 for example will move the text up by 4 pixels and &yoffset=4 will move the text down by 4 pixels.

Displays scrolling text for x loops. See the Queue feature described below for more info on the queue works.  Ex. &l=5 will loop the scrolling text 5 times.

Note if the text is shorter than the length of the display (Pixelcade is 132 pixels wide for example), then the text will not scroll.

If LCDLEDCompliment=yes in settings.ini (this is the default), then the additional param &led is sent to the LCD call which then tells Pixelcade LCD not to scroll text since there is already a Pixelcade LED that is scrolling text. Ex. http://pixelcadedx-xxxxxxxx:8080/text?t=Now Playing Pacman&led 

http://localhost:8080/arcade/stream/[console name]/[rom name]?t=[alt-scrolling-text]

If a matching PNG or GIF image is not found, then display scrolling text (Ex. Game Playing Asteroids Deluxe)

The same optional text parameters (font, size, lines, yoffset, etc.) can be used here too.

http://localhost:8080/arcade/stream/[console name]/[rom name]?l=x

Loops a GIF animations x times or displays a still image PNG for x seconds

QUEUE FEATURE

If another loop command (GIF, PNG, or scrolling text) is sent while in the current loop, that next loop command will be sent to a Queue for playback after the current loop command has finished. The Queue can contain an unlimited number of commands in any combination of GIF animations, still PNG images, and scrolling text.

To abort and clear all items in the Queue, simply send a new command that does not contain the loop parameter (&l=x) or send a write command. This command will immediately take priority, start, and empty the Queue.

Note that the display will be cleared / blanked out after the last loop command in the Queue has finished unless a loop value of 99999 is specified which tells Pixelcade to let the previous Queue item finish and then will stay on the last PNG or GIF until its interrupted.

If using the Queue feature in a custom script, ensure all your calls have the additional param &event=FEScroll

http://localhost:8080/arcade/stream/[console name]/[rom name]?t=[scrolling text]&l=[number of times to loop the GIF or seconds if a PNG]&color=[text color]&cycle

CYCLE MODE

Cycle indefinitely between a GIF or PNG and scrolling text.  A typical use case would be launching a game and then displaying a marquee for say 5 seconds and then scrolling high scores and then back to the marquee. If the target is a PNG, the PNG will display for x seconds where x is the loop param. If the target is a GIF, the GIF will loop only 1 time. The text will always scroll only one time before cycling back to the PNG or GIF.  To interrupt the cycle, you must send another API command without a loop parameter.

Example:

http://localhost:8080/arcade/stream/mame/pacman?t=High%20Socres%20Al%20200,000%20Erin%203,000&l=1&color=green&cycle

http://localhost:8080/arcade/stream/[console name]/[rom name]?event=[Arcade Front End Event Flag]

Possible Values:

  • FEStart
  • FEScroll
  • GameStart
  • FEScreenSaver
  • FEQuit

ARCADE FRONT END EVENT FLAGS

For arcade front ends integrating with Pixelcade, it’s highly recommended to add events flag to each API call as this gives Pixelcade context enabling Pixelcade to know if the event is coming from front end scrolling or a game launch for example.

  • FEStart – when your front end is launched (optional)
  • FEScroll – when scrolling through games (wheels for example) through the front end but not actually launching the game (required)
  • GameStart – launching the game (required)
  • FEScreenSaver (optional)
  • FEQuit – when exiting your front end (nice to have)

Note: case sensitive

Example:

http://localhost:8080/arcade/stream/mame/pacman?event=FEScroll

http://localhost:8080/news?start

http://localhost:8080/news?stop

NEWS TICKER

Starts and stops a scrolling text ticker based on content from RSS feeds

  • feed (optional): A comma-separated list of RSS feed URLs. Defaults to:
    https://news.yahoo.com/rss,https://finance.yahoo.com/news/rssindex
  • c (optional): Font color. Supported values are:
    • red, green, blue, yellow, white, cyan, magenta, orange
    • Defaults to red if not provided or invalid.
  • s (optional): Scroll speed as an integer. Defaults to 7.
  • newsTickerRefresh (optional): Refresh interval in minutes. Must be:
    • Minimum: 30
    • Maximum: 14400 (4 hours)
    • Defaults to 60 if not provided or invalid.

Example URL Formats

Minimal Starting Command

/news?start

Custom Starting Command

With feeds, font color, speed, and refresh interval:

/news?start&feed=https://news.site1.com/rss,https://news.site2.com/rss&c=blue&s=10&newsTickerRefresh=120

Stopping Command

/news?stop

If an invalid query parameter (e.g., no start or stop) is provided, the API will return an error.

http://localhost:8080/achievements/stream/[console name]/[achievement_id]?t=[achievement_scrolling_text&currentgame=[rom name]

ACHIEVEMENTS

This API is specifically for integration with RetroAchievements , here is an example.

If a PNG or GIF matching the achievements ID file name exists in <your Pixelcade folder>/achievements , then that file will play , then followed by the achievements scrolling text for 1 loop, and then lastly the game marquee will display that matches the console and rom name. If the achievements ID file does not exist (which will be the more common case), then a random animation (between 10 animations) will display, then the achievements scrolling text, and then the game marquee.

Example:

http://localhost:8080/achievements/stream/coleco/177575?t=”First Flight : Clear 3 rounds of Skill Level 1″&currentgame=zaxxon

http://localhost:8080/pinball/table/animation

PINBALL EVENT ANIMATIONS

Displays animations specifically in the /pinball artwork folder, click here for demo

ex. http://localhost:8080/pinball/btmn_106/s4

If a second pinball API comes in when the first one did not complete yet, the animations will overlay

If the table does not exist, it will default to animations in the pinball/auto folder. The default animations in pinball/auto are s1, s2, s3…. s16.

For training mode to see what animation name the pinball table is passing (so you can later add the corresponding artwork), use

http://localhost:8080/pinball/btmn_106/s4?training which will then scroll text on Pixelcade LED showing what animation name is being sent by the table.

Note this is only available on the Pixelcace LED legacy version at this time

http://localhost:8080/text?t=&l=xDisplays scrolling text for x loops. The Queue feature described above applies also to scrolling text with the loop parameter.
API Access to Widgets

Weather

/weather?location=x

x can be a zip code or a city/country name

Clock

/clock?12h=true&showMilliseconds=true&showSeconds=true&timeSeparator=:&timeFormat=24&color=blue

Explanation of Parameters:

  • 12h (optional): A boolean indicating whether to use 12-hour format. Accepts true or false.
  • showMilliseconds (optional): A boolean to indicate whether to show milliseconds. Accepts true or false.
  • showSeconds (optional): A boolean to indicate whether to show seconds. Accepts true or false.
  • timeSeparator (optional): A string to specify the separator between hours, minutes, and seconds (e.g., :).
  • timeFormat (optional): A string to specify the time format (e.g., 24 for 24-hour format).
  • color (optional): A string representing the color of the clock text. Accepted values are:
    • red, green, blue, yellow, white, cyan, magenta, orange.

Sports Scores Ticker

/sports/x?teams=a,b,c

x can be: nfl, nba, nhl, mlb, wnba, eng.1,esp.1,ger.1,ita.1,fra.1,uefa.champions,college-football,mens-college-basketball,womens-college-basketball,college-baseball

teams are optional and will filters scores to just those team(s) if specified, here are the values for popular sports leagues:

 nfl: [
        { code: “WSH”, name: “Washington Commanders” },
        { code: “ARI”, name: “Arizona Cardinals” },
        { code: “ATL”, name: “Atlanta Falcons” },
        { code: “BAL”, name: “Baltimore Ravens” },
        { code: “BUF”, name: “Buffalo Bills” },
        { code: “CAR”, name: “Carolina Panthers” },
        { code: “CHI”, name: “Chicago Bears” },
        { code: “CIN”, name: “Cincinnati Bengals” },
        { code: “CLE”, name: “Cleveland Browns” },
        { code: “DAL”, name: “Dallas Cowboys” },
        { code: “DEN”, name: “Denver Broncos” },
        { code: “DET”, name: “Detroit Lions” },
        { code: “GB”, name: “Green Bay Packers” },
        { code: “HOU”, name: “Houston Texans” },
        { code: “IND”, name: “Indianapolis Colts” },
        { code: “JAX”, name: “Jacksonville Jaguars” },
        { code: “KC”, name: “Kansas City Chiefs” },
        { code: “LAC”, name: “Los Angeles Chargers” },
        { code: “LAR”, name: “Los Angeles Rams” },
        { code: “LV”, name: “Las Vegas Raiders” },
        { code: “MIA”, name: “Miami Dolphins” },
        { code: “MIN”, name: “Minnesota Vikings” },
        { code: “NE”, name: “New England Patriots” },
        { code: “NO”, name: “New Orleans Saints” },
        { code: “NYG”, name: “New York Giants” },
        { code: “NYJ”, name: “New York Jets” },
        { code: “PHI”, name: “Philadelphia Eagles” },
        { code: “PIT”, name: “Pittsburgh Steelers” },
        { code: “SEA”, name: “Seattle Seahawks” },
        { code: “SF”, name: “San Francisco 49ers” },
        { code: “TB”, name: “Tampa Bay Buccaneers” },
        { code: “TEN”, name: “Tennessee Titans” }
    ],
    nba: [
        { code: “WSH”, name: “Washington Wizards” },
        { code: “ATL”, name: “Atlanta Hawks” },
        { code: “BKN”, name: “Brooklyn Nets” },
        { code: “BOS”, name: “Boston Celtics” },
        { code: “CHA”, name: “Charlotte Hornets” },
        { code: “CHI”, name: “Chicago Bulls” },
        { code: “CLE”, name: “Cleveland Cavaliers” },
        { code: “DAL”, name: “Dallas Mavericks” },
        { code: “DEN”, name: “Denver Nuggets” },
        { code: “DET”, name: “Detroit Pistons” },
        { code: “GS”, name: “Golden State Warriors” },
        { code: “HOU”, name: “Houston Rockets” },
        { code: “IND”, name: “Indiana Pacers” },
        { code: “LAC”, name: “Los Angeles Clippers” },
        { code: “LAL”, name: “Los Angeles Lakers” },
        { code: “MEM”, name: “Memphis Grizzlies” },
        { code: “MIA”, name: “Miami Heat” },
        { code: “MIL”, name: “Milwaukee Bucks” },
        { code: “MIN”, name: “Minnesota Timberwolves” },
        { code: “NO”, name: “New Orleans Pelicans” },
        { code: “NY”, name: “New York Knicks” },
        { code: “OKC”, name: “Oklahoma City Thunder” },
        { code: “ORL”, name: “Orlando Magic” },
        { code: “PHI”, name: “Philadelphia 76ers” },
        { code: “PHX”, name: “Phoenix Suns” },
        { code: “POR”, name: “Portland Trail Blazers” },
        { code: “SA”, name: “San Antonio Spurs” },
        { code: “SAC”, name: “Sacramento Kings” },
        { code: “TOR”, name: “Toronto Raptors” },
        { code: “UTAH”, name: “Utah Jazz” }
    ],
    nhl: [
        { code: “WSH”, name: “Washington Capitals” },
        { code: “ANA”, name: “Anaheim Ducks” },
        { code: “ARI”, name: “Arizona Coyotes” },
        { code: “BOS”, name: “Boston Bruins” },
        { code: “BUF”, name: “Buffalo Sabres” },
        { code: “CAR”, name: “Carolina Hurricanes” },
        { code: “CBJ”, name: “Columbus Blue Jackets” },
        { code: “CGY”, name: “Calgary Flames” },
        { code: “CHI”, name: “Chicago Blackhawks” },
        { code: “COL”, name: “Colorado Avalanche” },
        { code: “DAL”, name: “Dallas Stars” },
        { code: “DET”, name: “Detroit Red Wings” },
        { code: “EDM”, name: “Edmonton Oilers” },
        { code: “FLA”, name: “Florida Panthers” },
        { code: “LA”, name: “Los Angeles Kings” },
        { code: “MIN”, name: “Minnesota Wild” },
        { code: “MTL”, name: “Montreal Canadiens” },
        { code: “NJ”, name: “New Jersey Devils” },
        { code: “NSH”, name: “Nashville Predators” },
        { code: “NYI”, name: “New York Islanders” },
        { code: “NYR”, name: “New York Rangers” },
        { code: “OTT”, name: “Ottawa Senators” },
        { code: “PHI”, name: “Philadelphia Flyers” },
        { code: “PIT”, name: “Pittsburgh Penguins” },
        { code: “SEA”, name: “Seattle Kraken” },
        { code: “SJ”, name: “San Jose Sharks” },
        { code: “STL”, name: “St. Louis Blues” },
        { code: “TB”, name: “Tampa Bay Lightning” },
        { code: “TOR”, name: “Toronto Maple Leafs” },
        { code: “VAN”, name: “Vancouver Canucks” },
        { code: “VGK”, name: “Vegas Golden Knights” },
        { code: “WPG”, name: “Winnipeg Jets” }
    ],
    mlb: [
        { code: “ARI”, name: “Arizona Diamondbacks” },
        { code: “ATL”, name: “Atlanta Braves” },
        { code: “BAL”, name: “Baltimore Orioles” },
        { code: “BOS”, name: “Boston Red Sox” },
        { code: “CHC”, name: “Chicago Cubs” },
        { code: “CHW”, name: “Chicago White Sox” },
        { code: “CIN”, name: “Cincinnati Reds” },
        { code: “CLE”, name: “Cleveland Guardians” },
        { code: “COL”, name: “Colorado Rockies” },
        { code: “DET”, name: “Detroit Tigers” },
        { code: “HOU”, name: “Houston Astros” },
        { code: “KC”, name: “Kansas City Royals” },
        { code: “LAA”, name: “Los Angeles Angels” },
        { code: “LAD”, name: “Los Angeles Dodgers” },
        { code: “MIA”, name: “Miami Marlins” },
        { code: “MIL”, name: “Milwaukee Brewers” },
        { code: “MIN”, name: “Minnesota Twins” },
        { code: “NYM”, name: “New York Mets” },
        { code: “NYY”, name: “New York Yankees” },
        { code: “OAK”, name: “Oakland Athletics” },
        { code: “PHI”, name: “Philadelphia Phillies” },
        { code: “PIT”, name: “Pittsburgh Pirates” },
        { code: “SD”, name: “San Diego Padres” },
        { code: “SEA”, name: “Seattle Mariners” },
        { code: “SF”, name: “San Francisco Giants” },
        { code: “STL”, name: “St. Louis Cardinals” },
        { code: “TB”, name: “Tampa Bay Rays” },
        { code: “TEX”, name: “Texas Rangers” },
        { code: “TOR”, name: “Toronto Blue Jays” },
        { code: “WSH”, name: “Washington Nationals” }
    ],
    wnba: [
        { code: “ATL”, name: “Atlanta Dream” },
        { code: “CHI”, name: “Chicago Sky” },
        { code: “CONN”, name: “Connecticut Sun” },
        { code: “DAL”, name: “Dallas Wings” },
        { code: “IND”, name: “Indiana Fever” },
        { code: “LA”, name: “Los Angeles Sparks” },
        { code: “LV”, name: “Las Vegas Aces” },
        { code: “MIN”, name: “Minnesota Lynx” },
        { code: “NY”, name: “New York Liberty” },
        { code: “PHX”, name: “Phoenix Mercury” },
        { code: “SEA”, name: “Seattle Storm” },
        { code: “WSH”, name: “Washington Mystics” }
    ],
    “eng.1”: [
        { code: “ARS”, name: “Arsenal” },
        { code: “AVL”, name: “Aston Villa” },
        { code: “BRE”, name: “Brentford” },
        { code: “BOU”, name: “AFC Bournemouth” },
        { code: “BHA”, name: “Brighton & Hove Albion” },
        { code: “BUR”, name: “Burnley” },
        { code: “CHE”, name: “Chelsea” },
        { code: “CRY”, name: “Crystal Palace” },
        { code: “EVE”, name: “Everton” },
        { code: “FUL”, name: “Fulham” },
        { code: “LIV”, name: “Liverpool” },
        { code: “LUT”, name: “Luton Town” },
        { code: “MCI”, name: “Manchester City” },
        { code: “MUN”, name: “Manchester United” },
        { code: “NEW”, name: “Newcastle United” },
        { code: “NFO”, name: “Nottingham Forest” },
        { code: “SHU”, name: “Sheffield United” },
        { code: “TOT”, name: “Tottenham Hotspur” },
        { code: “WHU”, name: “West Ham United” },
        { code: “WOL”, name: “Wolverhampton Wanderers” }
    ],
    “ger.1”: [
        { code: “FCA”, name: “FC Augsburg” },
        { code: “FCU”, name: “FC Union Berlin” },
        { code: “BOC”, name: “VfL Bochum” },
        { code: “SVW”, name: “SV Werder Bremen” },
        { code: “BVB”, name: “Borussia Dortmund” },
        { code: “SGE”, name: “Eintracht Frankfurt” },
        { code: “SCF”, name: “SC Freiburg” },
        { code: “HEI”, name: “FC Heidenheim” },
        { code: “TSG”, name: “TSG 1899 Hoffenheim” },
        { code: “KIE”, name: “Holstein Kiel” },
        { code: “RBL”, name: “RB Leipzig” },
        { code: “B04”, name: “Bayer 04 Leverkusen” },
        { code: “M05”, name: “FSV Mainz 05” },
        { code: “BMG”, name: “Borussia Mönchengladbach” },
        { code: “FCB”, name: “FC Bayern München” },
        { code: “STP”, name: “FC St. Pauli” },
        { code: “VFB”, name: “VfB Stuttgart” },
        { code: “WOB”, name: “VfL Wolfsburg” }
    ],
    “fra.1”: [
        { code: “SCO”, name: “Angers SCO” },
        { code: “AJA”, name: “AJ Auxerre” },
        { code: “BRE”, name: “Stade Brestois 29” },
        { code: “HAC”, name: “Le Havre AC” },
        { code: “LIL”, name: “Lille OSC” },
        { code: “ASM”, name: “AS Monaco” },
        { code: “MON”, name: “Montpellier HSC” },
        { code: “NAN”, name: “FC Nantes” },
        { code: “NICE”, name: “OGC Nice” },
        { code: “OL”, name: “Olympique Lyonnais” },
        { code: “OM”, name: “Olympique de Marseille” },
        { code: “PSG”, name: “Paris Saint-Germain” },
        { code: “RCL”, name: “RC Lens” },
        { code: “SR”, name: “Stade de Reims” },
        { code: “REN”, name: “Stade Rennais FC” },
        { code: “ASSE”, name: “AS Saint-Étienne” },
        { code: “STR”, name: “RC Strasbourg Alsace” },
        { code: “TFC”, name: “Toulouse FC” }
    ],
    “esp.1”: [
        { “code”: “ALM”, “name”: “Almería” },
        { “code”: “ATM”, “name”: “Atlético Madrid” },
        { “code”: “BAR”, “name”: “Barcelona” },
        { “code”: “BET”, “name”: “Real Betis” },
        { “code”: “CAD”, “name”: “Cádiz” },
        { “code”: “CEL”, “name”: “Celta Vigo” },
        { “code”: “EIB”, “name”: “Eibar” },
        { “code”: “ELC”, “name”: “Elche” },
        { “code”: “GET”, “name”: “Getafe” },
        { “code”: “GRN”, “name”: “Granada” },
        { “code”: “LEV”, “name”: “Levante” },
        { “code”: “LUG”, “name”: “Lugo” },
        { “code”: “MAL”, “name”: “Málaga” },
        { “code”: “RAK”, “name”: “Rayo Vallecano” },
        { “code”: “REAL”, “name”: “Real Madrid” },
        { “code”: “RSO”, “name”: “Real Sociedad” },
        { “code”: “VLL”, “name”: “Valladolid” },
        { “code”: “VAL”, “name”: “Valencia” }
],
“ita.1”: [
        { “code”: “ATA”, “name”: “Atalanta” },
        { “code”: “BOL”, “name”: “Bologna” },
        { “code”: “CAG”, “name”: “Cagliari” },
        { “code”: “EMP”, “name”: “Empoli” },
        { “code”: “FIO”, “name”: “Fiorentina” },
        { “code”: “GEN”, “name”: “Genoa” },
        { “code”: “INTER”, “name”: “Inter Milan” },
        { “code”: “JUVE”, “name”: “Juventus” },
        { “code”: “LAZ”, “name”: “Lazio” },
        { “code”: “LEC”, “name”: “Lecce” },
        { “code”: “MIL”, “name”: “Milan” },
        { “code”: “MON”, “name”: “Monza” },
        { “code”: “NAP”, “name”: “Napoli” },
        { “code”: “ROM”, “name”: “Roma” },
        { “code”: “SAMP”, “name”: “Sampdoria” },
        { “code”: “SPE”, “name”: “Spezia” },
        { “code”: “TOR”, “name”: “Torino” },
        { “code”: “UDI”, “name”: “Udinese” }
],
“por.1”: [
        { “code”: “ABA”, “name”: “Abissola” },
        { “code”: “BEN”, “name”: “Benfica” },
        { “code”: “BOL”, “name”: “Belenenses SAD” },
        { “code”: “FAM”, “name”: “Famalicão” },
        { “code”: “MAR”, “name”: “Marítimo” },
        { “code”: “NAC”, “name”: “Nacional” },
        { “code”: “POR”, “name”: “Portimonense” },
        { “code”: “PRA”, “name”: “Praiense” },
        { “code”: “RIO”, “name”: “Rio Ave” },
        { “code”: “SCP”, “name”: “Sporting CP” },
        { “code”: “TON”, “name”: “Tondela” },
        { “code”: “VIT”, “name”: “Vitória de Guimarães” },
        { “code”: “BRG”, “name”: “Braga” },
        { “code”: “MAR”, “name”: “Marítimo” },
        { “code”: “VSC”, “name”: “Vitória SC” },
        { “code”: “PFC”, “name”: “Paços de Ferreira” }
],
“ned.1”: [
        { “code”: “ADO”, “name”: “ADO Den Haag” },
        { “code”: “AZ”, “name”: “AZ Alkmaar” },
        { “code”: “BAS”, “name”: “FC Basel” },
        { “code”: “DEN”, “name”: “FC Den Bosch” },
        { “code”: “FCO”, “name”: “FC Utrecht” },
        { “code”: “FYN”, “name”: “Feyenoord” },
        { “code”: “HEE”, “name”: “FC Heerenveen” },
        { “code”: “HER”, “name”: “Heracles Almelo” },
        { “code”: “PEC”, “name”: “PEC Zwolle” },
        { “code”: “PSV”, “name”: “PSV Eindhoven” },
        { “code”: “RKC”, “name”: “RKC Waalwijk” },
        { “code”: “SPE”, “name”: “Sparta Rotterdam” },
        { “code”: “VIT”, “name”: “Vitesse” },
        { “code”: “WIL”, “name”: “Willem II” },
        { “code”: “GRON”, “name”: “FC Groningen” }
],
“mex.1”: [
        { “code”: “AMERICA”, “name”: “Club América” },
        { “code”: “ATLAS”, “name”: “Atlas FC” },
        { “code”: “CHIVAS”, “name”: “Chivas Guadalajara” },
        { “code”: “CRUZAZUL”, “name”: “Cruz Azul” },
        { “code”: “FCJUAREZ”, “name”: “FC Juárez” },
        { “code”: “PACHUCA”, “name”: “Club Pachuca” },
        { “code”: “PUMAS”, “name”: “UNAM Pumas” },
        { “code”: “TIGRES”, “name”: “Tigres UANL” },
        { “code”: “TOLUCA”, “name”: “Deportivo Toluca” },
        { “code”: “SANTOS”, “name”: “Santos Laguna” },
        { “code”: “LEON”, “name”: “Club León” },
        { “code”: “MORELIA”, “name”: “Monarcas Morelia” },
        { “code”: “PUEBLA”, “name”: “Club Puebla” },
        { “code”: “XALAPA”, “name”: “Veracruz” },
        { “code”: “QUERETARO”, “name”: “Querétaro” }
],
“uefa.champions”: [
        { “code”: “ARS”, “name”: “Arsenal” },
        { “code”: “ATLETI”, “name”: “Atlético Madrid” },
        { “code”: “BAR”, “name”: “Barcelona” },
        { “code”: “BAY”, “name”: “Bayern Munich” },
        { “code”: “BVB”, “name”: “Borussia Dortmund” },
        { “code”: “BENE”, “name”: “Benfica” },
        { “code”: “BRUGGE”, “name”: “Club Brugge” },
        { “code”: “CHE”, “name”: “Chelsea” },
        { “code”: “DORTMUND”, “name”: “Borussia Dortmund” },
        { “code”: “INTER”, “name”: “Inter Milan” },
        { “code”: “JUVE”, “name”: “Juventus” },
        { “code”: “LIVERPOOL”, “name”: “Liverpool” },
        { “code”: “MANC”, “name”: “Manchester City” },
        { “code”: “PSG”, “name”: “Paris Saint-Germain” },
        { “code”: “REAL”, “name”: “Real Madrid” },
        { “code”: “NAPOLI”, “name”: “Napoli” },
        { “code”: “ROMA”, “name”: “AS Roma” }
], “usa.1”: [
        { “code”: “ATL”, “name”: “Atlanta United FC” },
        { “code”: “CHI”, “name”: “Chicago Fire FC” },
        { “code”: “CLT”, “name”: “Charlotte FC” },
        { “code”: “COL”, “name”: “Colorado Rapids” },
        { “code”: “DC”, “name”: “D.C. United” },
        { “code”: “FCB”, “name”: “FC Cincinnati” },
        { “code”: “LAFC”, “name”: “Los Angeles FC” },
        { “code”: “LAG”, “name”: “LA Galaxy” },
        { “code”: “MIA”, “name”: “Inter Miami CF” },
        { “code”: “MIN”, “name”: “Minnesota United FC” },
        { “code”: “MTL”, “name”: “CF Montréal” },
        { “code”: “NE”, “name”: “New England Revolution” },
        { “code”: “NYC”, “name”: “New York City FC” },
        { “code”: “NYRB”, “name”: “New York Red Bulls” },
        { “code”: “ORL”, “name”: “Orlando City SC” },
        { “code”: “PHI”, “name”: “Philadelphia Union” },
        { “code”: “PORT”, “name”: “Portland Timbers” },
        { “code”: “RSL”, “name”: “Real Salt Lake” },
        { “code”: “SJ”, “name”: “San Jose Earthquakes” },
        { “code”: “SEA”, “name”: “Seattle Sounders FC” },
        { “code”: “SKC”, “name”: “Sporting Kansas City” },
        { “code”: “TOR”, “name”: “Toronto FC” },
        { “code”: “VAN”, “name”: “Vancouver Whitecaps FC” }
]
 
Stock and Crypto Ticker
 
/stocks?tickers=AAPL,GOOG,MSFT&c=blue&s=10

Explanation of Parameters:

  • tickers (optional): A comma-separated list of stock ticker symbols (e.g., AAPL,GOOG,MSFT). If not provided, defaults to "AAPL,GOOG,MSFT".
  • c (optional): A string representing the color of the stock ticker text. This corresponds to a valid color name (e.g., red, blue, green). If not provided, defaults to a preset color in the code.
  • s (optional): A string representing the speed of the ticker’s scrolling. The value is an integer. If not provided or invalid, defaults to 10.
http://localhost:8080/info

Returns a JSON with info and settings from pixelcade.ini

{"name":"My Pixelcade LED","type":"LED","hostname":"al-xps15","ipAddress":"192.168.87.47","firmwareVersion":"PIXR0021","hardwareID":"PIXL0025","bootLoaderID":"IOIO0401","softwareVersion":"5.7.0-debug (89044191)","resolution":"128x32","pixelcadeRoot":"C:\\Pixelcade","bindAddr":"0.0.0.0","bindPort":8080,"defaultFont":"C:\\Pixelcade\\fonts\\Arial Narrow 7.ttf","defaultFontColor":"red","defaultFontColorRandom":true,"defaultFontSize":28,"devicePath":"auto","deviceScan":false,"fuzzyMatching":true,"pngFuzzyDistanceThreshold":20,"pngFuzzyMaxMatchesThreshold":40,"noIntro":false,"startupImage":"mame/pixelcade.png","startupMode":false,"startupText":"Welcome to Pixelcade","systemImage":"","debugLogging":false,"traceLogging":false,"noLogging":false,"colorLogging":false,"initDelay":0,"demoMode":false,"noMdns":false}
http://localhost:8080/settings?key=<key-name>&value<true or false or string>

Settings

Valid Key names are:

fuzzyMatching
debugLogging
traceLogging
noLogging
colorLogging
defaultFontColorRandom
noIntro
demoMode
noMdns
deviceScan
displayName
 
If valid key and value, returns:
 
{"key":"fuzzyMatching","value":"false"}
if invalid key or value, returns
 
{"key":"error","value":"wrongKeyName is not a valid setting key"}
 
http://localhost:8080/animations/stream/[file name]Streams or writes an animation that exists in the /animations/gifsource folder. Add the parameter ?r to return a random animation.
http://localhost:8080/animations/listReturns a list of animation names from /animations
http://localhost:8080/still/listReturns a list of single frame image names from /images
http://localhost:8080/arcade/listReturns a list of mame game names from /mame
http://localhost:8080/currentgameReturns the name of the last game selected in the format console%game-name Ex. mame%pacman

REST API Call Examples

REST Call Examples

Result

http://localhost:8080/arcade/stream/Atari%202600/pacman

Streams pacman PNG or GIF for the Atari 2600 console

http://localhost:8080/arcade/stream/Atari%202600/pacman?nogif

Displays pacman.png for the Atari 2600 console and ignores the matching GIF

http://localhost:8080/arcade/stream/Atari%202600/pacman?l=3&gifonly

Loops pacman.gif 3 times for the Atari 2600 console and ignores the matching PNG

http://localhost:8080/arcade/stream/nes/WURM%20-%20Journey%20to%20the%20Center%20of%20the%20World(U).zip

Streams Journey to the center of the World for the NES console

http://localhost:8080/arcade/stream/mame/milliped

Streams Millipede for the MAME console

http://localhost:8080/arcade/write/mame/1942

Writes 1942 for the MAME console

http://pixelcade.local:8080/console/stream/nes

Streams the default console marquee for nes. Also note that pixelcade.local is used here vs. localhost where pixelcade.local is the host name of a Raspberry Pi on your Wifi network that has been configured for Pixelcade.

http://localhost:8080/text?t=Hello%20World

Scrolls Hello World text

http://localhost:8080/text?t=Hello%20World&c=ff6d00

Scrolls Hello World text in light orange (hex color code)

http://localhost:8080/text?t=Game%20Playing%20Pacman&l=1&c=yellow&s=50

http://localhost:8080/arcade/stream/mame/pacman

Streams “Game Playing Pacman” in yellow one time in a slower speed of 50 and then sets the still image pacman PNG indefinitely

http://localhost:8080/text?t=Game%20Playing%20Pacman&l=1&c=blue

http://localhost:8080/arcade/stream/mame/pacman.png?l=3

http://localhost:8080/arcade/stream/mame/pacghosts.gif?l=2

Streams “Game Playing Pacman” in blue one time, then displays pacman PNG for 3 seconds, then loops the pacghosts GIF two times, and then clears the display blank.  

http://localhost:8080/arcade/stream/mame/Missing-Game?t=Game%20Playing%20Missing-Game&c=green

If missing-game.png or missing-game.gif does not exist, scrolls the text “Game Playing Missing Game” in green indefinitely

http://localhost:8080/arcade/stream/mame/Missing-Game?t=Game%20Playing%20Missing-Game&l=1

If missing-game.png or missing-game.gif does not exist, scrolls the text “Game Playing Missing Game” one time

http://localhost:8080/text/color/green

Changes scrolling text color to green

http://localhost:8080/text/speed/50

Changes scrolling text speed to 50. Smaller number is faster scrolling and larger number is slower scrolling. Range: 10 – 150

http://localhost:8080/arcade/write/user/

For non arcade use cases, you can use all the above features of the API and place your PNG or GIF files in the pixelcade install directory/user

http://localhost:8080/animations/stream/0rain

Streams the 0rain.gif file in the animations folder

http://localhost:8080/animations/stream/0rain?l=3

Streams the 0rain.gif file in the animations folder 3 times

curl -i -X POST -H "Content-Type: multipart/form-data" -F "upload=@/Users/al/artwork/galaga.png" -F "upload-type=STILL_IMAGE" http://localhost:8080/upload

Using Curl or libcurl, uploads a PNG to $HOME/pixelcade/images

curl -i -X POST -H "Content-Type: multipart/form-data" -F "upload=@/Users/artwork/pacman.gif" -F "upload-type=ANIMATED_GIF" http://localhost:8080/uploadUsing Curl or libcurl, uploads a GIF to $HOME/pixelcade/animations
curl -i -X POST -H "Content-Type: multipart/form-data" -F "upload=@/Users/al/artwork/pacman.PNG" -F "upload-type=STILL_IMAGE" -F "console=alu" -F "displaynow=0" http://localhost:8080/uploadplatformUsing Curl or libcurl, uploads a PNG to $HOME/pixelcade/ALU but doesn’t stream/display the PNG
curl -i -X POST -H "Content-Type: multipart/form-data" -F "upload=@/Users/al/artwork/pacman.gif" -F "upload-type=ANIMATED_GIF" -F "console=MAME" -F "displaynow=1" http://localhost:8080/uploadplatformUsing Curl or libcurl, uploads a GIF to $HOME/pixelcade/mame AND streams/displays the GIF

Note the URL cannot contain spaces and cannot accept a full rom file path, just include the rom name (ex. 1942.zip) or the rom name without extension (Ex. 1942) 

Pixelcade LCD API

These additional APIs only apply to Pixelcade LCD and will NOT function on Pixelcade LED. These APIs for example are used by the Pixelcade Companion web application.

Note that each Pixelcade LCD has a unique 8-digit ID so replace all calls with the unique of the target Pixelcade LCD. You can find the unique ID in the Pixelcade settings.ini file after it’s been paired or also in the Pixelcade iOS app. For example a given Pixelcade LCD has the unique ID of: f26967ec , then use for API calls:

pixelcadedx-f26967ec.local:8080
::Pixelcade Device Info::
/v2/info/
GET Returns a PixelcadeLCD object with specifications of the Pixelcade

Sample:
http://pixelcadedx-xxxxxxxx.local:8080/v2/info
{
"name": "Tricks \u0027n Lies",
"hostname": "pixelcadedx-xxxxxxxx",
"firmwareVersion": "2.9.0.9",
"resolution": {
"width": 1920,
"height": 360
},
"isPaired": false,
"hasJoinedNetwork": true
}
::Pixelcade Pairing::
/v2/utility/pairing/
GET Returns the current pairing state

Sample:
http://pixelcadedx-xxxxxxxx.local:8080/v2/utility/pairing/
{
 "succeeded" : true,
 "message" : "paired"
}

/v2/utility/pairing/set/on
GET Sets the system Pairing state to Paired. Returns a Status object
Sample:
http://pixelcadedx-xxxxxxxx.local:8080/v2/utility/pairing/set/on
{
 "succeeded" : true,
 "message" : "Device now set to Paired"
}
/v2/utility/pairing/set/off
GET Sets the system Pairing state to UnPaired. Returns a Status object
Sample:
http://pixelcadedx-xxxxxxxx.local:8080/v2/utility/pairing/set/off
{
 "succeeded" : true,
 "message" : "Device is now UnPaired"
}
::Pixelcade Default Marquee::
/v2/utility/marquee/set/:default marquee number [1,2,3]
GET Sets the system default marquee to one of the 3 options. Returns a Status object
NB - all other paths are rejected
Sample:
http://pixelcadedx-xxxxxxxx.local:8080/v2/utility/marquee/set/2 
{
 "succeeded" : true,
 "message" : "New Default Set@2"
}
::Pixelcade Dot Display Scores::
/score?s=<game score>
Sends a score to the Pixelcade Dot sub-displays only. The Pixelcade Dot sub-display can be of matrix or 7segment type. 
The score will not scroll if under 8 characters although the matrix type can also be 4 characters.
Technically text can also be sent here too in addition to numbers.
Note that not all text characters will render on the 7segment display. Sample: http://pixelcadedx-xxxxxxxx.local:8080/score?s=1000 score request received: 1000
Video Demo
::Marquee Thumbnails::
/v2/thumbnails/:system/:marquee
GET Returns a 640px wide thumbnail JPEG of the requested marquee as `image/jpg` type/data.
Endpoint Note - any non-2xx response should be checked for a Status Object explaining why the call failed.
:system denotes the api-level known system name, console, or system/category.
:marquee denotes the known "rom name" or "game title" and can be learned from the 'consoles' endpoint.
Sample:
http://pixelcadedx-xxxxxxxx.local:8080/v2/thumbnails/mame/deathsml
Result: jpg of marquee
::Marquee Editing::
/v2/marquees/:system/:marquee/display
POST Displays the received JPG as the Marquee for game path, temporarily. Returns as Status Object
NB: The *required* 'Content-Type' for these requests is 'image/jpg'. All others will be rejected.
Additionally, all images will be resized to the display's native resolution
Sample:
curl -X POST -H "Content-Type: image/jpg" "http://pixelcadedx-f26967ec.local:8080/v2/marquees/mame/blazstar/display" --data-binary "@blazstar.jpg"

Result:
{
"success": true,
"message": "Marquee Displayed."
}

/v2/marquees/:system/:marquee/save
POST Displays the received JPG as the Marquee for game path and saves/replaces it. Returns as Status Object

Sample:
curl -X POST -H "Content-Type: image/jpg" "http://pixelcadedx-f26967ec.local:8080/v2/marquees/mame/blazstar/display" --data-binary "@blazstar.jpg"

Result:
{
"success": true,
"message": "Marquee Updated."
}

/v2/marquees/:system/:marquee/undo
POST Reverts the Marquee for game path to previous version. Returns as Status Object
NB: There is one "level" of Undo. Intent is to revert a "just changed" marquee.
POST empty data to the /undo path

Sample:
curl -X POST -H "Content-Type: image/jpg" "http://pixelcadedx-f26967ec.local:8080/v2/marquees/mame/blazstar/undo" Result:
{
"success": true,
"message": "Marquee Reverted."
::Attract Mode::
/v2/utility/attractmode/timeline/
GET Returns the currently set Timeline object

Sample:
http://pixelcadedx-xxxxxxxx.local:8080/v2/utility/attractmode/timeline/
{
"isPlaying": false,
"media": [
{
"marqueeName": "pacman",
"delay": false,
"playVideo": true,
"playGIFs": false
},
{
"marqueeName": "blazstar",
"delay": true,
"playVideo": true,
"playGIFs": false
},
{
"marqueeName": "Legendary Axe I",
"delay": true,
"playVideo": true,
"playGIFs": false
},
{
"marqueeName": "Mario_Kart_8",
"delay": true,
"playVideo": true,
"playGIFs": false
},
{
"marqueeName": "blktiger",
"delay": true,
"playVideo": true,
"playGIFs": false
}
]
}

/v2/utility/attractmode/timeline/
POST Sets the Attract Mode Timeline to the provided Timeline object. Returns a Status object
NB call must set type to application/json for data sent

Sample:
curl -X POST -H 'content-type: application/json' http://pixelcaded-xxxxxxxxx.local:8080/v2/utility/attractmode/timeline/ \
-d @timeline.json
{
 "succeeded" : true,
 "message" : "Timeline set: 5 Items"
} /v2/utility/attractmode/timeline/play/
GET Starts playback of currently set Timeline. Returns Status objectSample:
http://pixelcadedx-xxxxxxxx.local:8080/v2/utility/attractmode/timeline/play/
{
 "succeeded" : true,
 "message" : "Starting timeline playback"
} /v2/utility/attractmode/timeline/stop/
GET Stops playback. Returns Status object

Sample:
http://pixelcadedx-xxxxxxxx.local:8080/v2/utility/attractmode/timeline/stop/
{
"success": "Stopping timeline playback"
}
:: System and Artwork Update::
/update
Pixelcade LCD Update Started
Please wait until your see the Update Complete message on your Pixelcade before doing anything else
Note: This initiates a bash shell update script that will check for new artwork and new firmware from a private GitHub repo

Sample: http://pixelcadedx-xxxxxxxx.local/update
::Settings::

settings?key=marqueeOverlays&value=no
Marquee Overlays Disabled
settings?key=marqueeOverlays&value=yes
Marquee Overlays Enabled

settings?key=SubDisplayScrollingOnly&value=no
Set to scroll text on both Pixelcade LCD and Pixelcade Dot Sub-Display
settings?key=SubDisplayScrollingOnly&value=yes
Disables scrolling text on LCD, text will only scroll on LED (if connected) or Pixelcade Dot Sub-Displays (if connected)

settings?key=ImageMarqueesOnly&value=no
Disables video snaps meaning only still image JPG marquees will be displayed
settings?key=ImageMarqueesOnly&value=yes
Enables video snaps

settings?key=font&value=<user selected font>
font changed to <user selected font>
Note the font must match one of the following or will return an error: 
{"Orbitron-SemiBold","Orbitron-Regular", "Eight-Bit-Madness", "Arial Narrow 7", "Benegraphic", "Candy Stripe (BRK)", "Casio FX-702P","Daddy Longlegs NF", "Decoder", "DIG DUG", "dotty", "DPComic","Early GameBoy","Fiddums Family", "Ghastly Panic", "GilbertC", "Gnuolane", "Grapevine", "Grinched", "Handwriting", "Harry P", "Haunting Attraction", "Minimal4", "Morris Roman", "MostlyMono", "Neon 80s", "Nintendo DS BIOS", "Not So Stout Deco", "Paulistana Deco", "Pixelated", "Pixeled", "RetroBoundmini", "RM Typerighter medium", "Samba Is Dead", "Shlop", "Space Patrol NF", "Star Jedi Hollow", "Star Jedi", "Still Time", "Tall Films Fine", "taller", "techno overload (BRK)", "TR2N", "TRON", "Vectroid", "Videophreak"};

settings?key=UseConsoleMapping&value=no
Set to NOT to use server side console mapping and instead use the console mapping from the local pixelcade running on your arcade front end devuce (this is the default behavior)
settings?key=UseConsoleMapping&value=yes
Set to use server side console mapping. Note only use this option if your arcade front end is making direct calls to Pixelcade LCD without using a local console.csv mapping function (this is uncommon)

settings?key=textColor&value=<user selected text color>
Scrolling text color changed to: <user selected color>
Note valid colors are: 
{ "random", "red", "cyan", "darkgray", "lightgray","orange","yellow","blue","gray","green","magenta","pink","white"}

settings?key=DisplayName&value=<New Pixelcade LCD Name>
Pixelcade LCD named changed to: <<New Pixelcade LCD Name>

settings?key=SetSubDisplayNumModules&value=<4 or 8>
Pixelcade Dot Sub-Display Set to <4 or 8> modules
Note: Value can only be 4 or 8

settings?key=PixelcadeDotType&value=<matrix or 7segment>
Sets Pixelcade Dot Sub-Display type to matrix or 7 segment
Note: Value can only be matrix or 7segment settings?key=getSettings Returns of a JSON of current settings: {"font":"Neon 80s","SubDisplayScrollingOnly":false,"ImageMarqueesOnly":false,"SubDisplayNumModules":"8","FontColor":"751d7d","consoleMapping":false,"marqueeOverlays":true} Samples: http://pixelcadedx-xxxxxxxx.local:8080/settings?key=ImageMarqueesOnly&value=yes http://pixelcadedx-c5d7aa96.local:8080/settings?key=getSettings
http://pixelcadedx-c59b51ea:8080/settings?key=PixelcadeDotType&value=7segment
::Marquee Lists::
/list/image/:system
Returns a list of all marquees for that system along with a count
Sample:
http://pixelcadedx-xxxxxxxx.local:8080/list/image/mame
Result: JSON list of image marquee names

/list/image/all
Returns a list of all marquees across all systems
Sample:
http://pixelcadedx-xxxxxxxx.local:8080/list/image/all
Result: JSON list of image marquee names

/list/video
Returns a list of all video marquees across all systems
Result: JSON list of video marquee names

Example:

{ "system": "atari2600", "count": 693, "files": [ "atari2600-Return to Haunted House (USA).jpg", "atari2600-Dice Puzzle (Europe).jpg", "atari2600-Pac-Man (Atari) (USA).jpg", "atari2600-G.I. Joe - Cobra Strike (USA).jpg", "atari2600-Up 'n Down (USA).jpg", "atari2600-Combat (USA).jpg", "atari2600-Breakout (USA) (alt).jpg", "atari2600-Buck Rogers - Planet of Zoom (USA) (alt).jpg", "atari2600-Pick 'n' Pile (Europe).jpg",.
}

API Notes:


As a “rule” all endpoints in the v2 api return JSON objects. The Api standard/default object returned is the Status Object, currently defined as:

{
"succeeded":
"message":
}

Sample:
{
 "succeeded" : false,
 "message" : "It broked :("
}

All API requests to any endpoint should check the HTTP-Response for a non 200-range response, as an indicator of if the call succeeded with the expected results returned, or if a Status Object with an error message was returned, per the “standard practices”

Customizing Pixelcade LED Marquees

Pixelcade and API License

Pixelcade software, API, and artwork is licensed for Pixelcade hardware only

Proudly powered by Wpopal.com