Skip to content

Commit

Permalink
: Add among-us [2024-05-19]
Browse files Browse the repository at this point in the history
  • Loading branch information
octospacc committed May 21, 2024
1 parent 2615fc1 commit 0419838
Show file tree
Hide file tree
Showing 9 changed files with 116 additions and 32 deletions.
2 changes: 1 addition & 1 deletion _includes/footer.html
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@
<script> document.querySelector('footer > div.nojs-menu').remove(); </script>

<!-- Include Google Analytics script -->
{% include stats.html %}
<!-- {% include stats.html %} -->

<!-- Include extra scripts -->
{% include extra-js.html %}
2 changes: 1 addition & 1 deletion _includes/software-embed.html
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
The following is the {{ page.software_data.release.source }} {{ page.software_data.platform | upcase }} {{ page.software_data.release.region }} {{ page.software_data.release.type }} version of the game.
<p>The following is the {{ page.software_data.release.source }} {{ page.software_data.platform | upcase }} {{ page.software_data.release.region }} {{ page.software_data.release.type }} version of the game.</p>

<p class="software-embed-wrapper"><script src="{{ site.baseurl }}/assets/js/software-embed.js"></script></p>
58 changes: 58 additions & 0 deletions _posts/2024-05-19-among-us.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
---
layout: "post"
title: "Among Us"
subtitle: "A single-player adaptation of the social deduction game set in a space-themed environment."
description: "The single-player web version of \"Among Us\" offers players the experience of the popular social deduction game where they must complete tasks on a spaceship while identifying an imposter among them. This version provides an AI-controlled environment, replicating the intrigue and challenge of the original multiplayer format."
image: "/assets/media/games/among-us/thumb-1920-385394.jpg"
image_source: "internal"
icon: "../../../../assets/media/games/among-us/8ddL1kuoNUB5vUvgDVjYY3_6HwQcrg1K2fd_R8soD-e2QYj8fT9cfhfh3G0hnSruLKec.jpg"
category: "games"
tags:
- "strategy"
- "suspense"
- "social"
- "meme"
- "drawn"
- "2d"
- "stealth"
- "sci-fi"
- "party"
author: "octobot"
mobygames_id: "149316"
software_data:
platform: "web"
frame_index: "amongus-online.net/game/amongus.html"
release:
region: "web"
source: "unknown"
type: "release"
year: "2018"
screen:
orientation: "landscape"
display: "fullscreen"
---

## About the game

The single-player web version of "Among Us" brings the intrigue and challenge of the popular social deduction game into a solo experience. Developed to mirror the core mechanics of the original multiplayer game, this adaptation allows players to immerse themselves in a space-themed environment where they must complete various tasks while identifying an AI-controlled imposter.

In the game, players assume the role of a Crewmate aboard a spaceship, tasked with completing a series of maintenance and repair duties critical to the ship's operation. These tasks range from simple activities like swiping a card in the admin room to more complex tasks such as aligning the spaceship's engines or recalibrating the communications system. The player's objective is to complete all tasks without falling prey to the imposter, who seeks to sabotage the mission and eliminate the crew.

The imposter, controlled by the game's AI, is programmed to blend in with the Crewmates by performing fake tasks and sabotaging the ship in strategic ways. The AI imposter can also eliminate Crewmates, creating an atmosphere of tension and suspicion. To win the game, the player must either complete all the tasks or successfully identify and vote the imposter off the ship during emergency meetings.

Emergency meetings can be called by finding a dead body or by pressing the emergency button located in the central meeting room. During these meetings, players can discuss their suspicions and vote on who they believe the imposter is. Since the game is single-player, these discussions are simulated through a series of dialogue options where the player must use their observational skills and logic to accuse the right character.

One of the unique aspects of the single-player version is its ability to maintain the suspense and social dynamics of the original game through AI interactions. The AI Crewmates exhibit a range of behaviors, including performing tasks, wandering around the spaceship, and reacting to sabotage events. This makes it challenging for the player to distinguish between genuine Crewmates and the imposter.

The game's visual style and interface remain faithful to the original "Among Us," featuring the familiar top-down perspective, vibrant character designs, and atmospheric sound effects. The space-themed setting adds an extra layer of immersion, with various rooms and compartments of the spaceship serving as the backdrop for the player's tasks and interactions.

The single-player web version of "Among Us" also includes customizable settings, allowing players to adjust the difficulty level by modifying the number of tasks, the visibility range, and the speed of the characters. This customization ensures that both newcomers and experienced players can tailor the game to their preferred level of challenge.

Additionally, this version is accessible directly through web browsers, making it easy to play without the need for downloads or installations. This convenience, combined with the engaging gameplay, makes it an appealing option for those looking to enjoy "Among Us" without requiring a group of friends to play with.

In conclusion, the single-player web version of "Among Us" successfully captures the essence of the original multiplayer game while providing a unique and enjoyable solo experience. Through clever AI design and faithful reproduction of the game's mechanics and visuals, it offers a compelling way to engage with the world of "Among Us" for those who prefer or need to play alone.

## Resources

* Official page of the game: <https://innersloth.itch.io/among-us>

27 changes: 21 additions & 6 deletions _sass/_SalaMuseoGames.scss
Original file line number Diff line number Diff line change
Expand Up @@ -43,8 +43,13 @@ footer a > svg
vertical-align: middle;
}

section.post > article {
word-wrap: break-word;
}

iframe.AppFrame,
iframe#software-embed-frame
iframe#software-embed-frame,
body.cinema-view > section.post > article > p.software-embed-wrapper > div.software-embed-container
{
height: calc(100vh - 4rem);
border: none;
Expand Down Expand Up @@ -72,15 +77,25 @@ body.cinema-view > section.post > aside {
}

body.cinema-view > section.post,
body.cinema-view > section.post > article {
body.cinema-view > section.post > article,
body.cinema-view > section.post > article > p.software-embed-wrapper,
body.cinema-view > section.post > article > p.software-embed-wrapper > #software-embed-frame,
body.cinema-view > section.post > article > p.software-embed-wrapper > div.software-embed-container,
body.cinema-view > section.post > article > p.software-embed-wrapper > div.software-embed-container > div#software-embed-frame,
body.cinema-view > section.post > article > p.software-embed-wrapper > div.software-embed-container > div#software-embed-frame > div.ejs_game {
margin-left: 0;
margin-right: 0;
padding-left: 0 !important;
padding-right: 0 !important;
min-width: 100vw;
}

body.cinema-view > section.post > article > p.software-embed-wrapper,
body.cinema-view > section.post > article > p.software-embed-wrapper > span.software-embed-controls {
padding-left: 1em;
padding-right: 1em;
}

/* body.cinema-view > section.post > article > p.software-embed-wrapper,
body.cinema-view > section.post > article > p.software-embed-wrapper > #software-embed-frame {
margin-left: 0;
margin-right: 0;
min-width: 100%;
}
} */
2 changes: 1 addition & 1 deletion assets/js/preferences.js
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ var Prefs = window.SalaMuseoGames.Prefs = {
idbBackupAndRestore.exportToJson(event.target.result).then(async function(json){
data.indexedDB[db] = json;
if (Object.keys(data.indexedDB).length === dbs.length) {
SMG.Util.useTempElement(SMG.Util.makeElement('a', ...(await makeDownloadObj(data))), function(elem){ elem.click() });
SMG.Util.useTempElement(SMG.Util.makeElement('a', (await makeDownloadObj(data))), function(elem){ elem.click() });
}
});
});
Expand Down
7 changes: 3 additions & 4 deletions assets/js/pwa.js
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ if (Prefs.pwaManifests.value || Prefs.softwarePwaManifests.value) {
var manifestData;
if (Prefs.softwarePwaManifests.value && Software) {
// specific manifests on games pages
var pageUrl = (location.href + ''); // TODO Url parameters to make the game open fullscreen and automatically start
var pageUrl = (location.href + '?pwaLaunch=1'); // TODO Url parameters to make the game open fullscreen and automatically start
manifestData = {
name: document.querySelector('.post-title').textContent,
description: document.querySelector('.post-subtitle').textContent,
Expand All @@ -45,13 +45,12 @@ if (Prefs.pwaManifests.value || Prefs.softwarePwaManifests.value) {
manifestData = {
name: ldData.name,
description: ldData.description,
start_url: sitePath,
scope: sitePath,
start_url: (sitePath + '/'),
scope: (sitePath + '/'),
display: "standalone",
};
}
manifestData = Object.assign(manifestData, {
scope: location.href,
background_color: (Software && Software.background_color || getComputedStyle(document.body).backgroundColor),
icons: [{
src: ((iconUrl || coverUrl) ? absoluteUrlFromRelative(iconUrl || coverUrl) : (sitePath + '/assets/img/icons/mediumtile.png')),
Expand Down
50 changes: 31 additions & 19 deletions assets/js/software-embed.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,29 +9,40 @@ var backend = data.backend;
var romUrl = (data.rom_url || `${bin1Path}/roms/${data.rom_index}.7z`);
var frameUrl = (data.frame_url || `${bin1Path}/${data.frame_index}`);

function button (name, onclick) { return `<button name="${name.split(' ')[0]}" onclick="(${onclick})(this)">${name}</button>` }
function makeButton (name, onclick) { return `<button name="${name.split(' ')[0]}" onclick="(${onclick})(this, this.parentElement.parentElement)">${name}</button>` }

var buttonEnlarge = button('Enlarge ↔️', function(){
document.body.classList[
function controlsHtml (picks) { return ( '<span class="software-embed-controls">' +
(picks.all || picks.focus ? makeButton('Focus 🔳️', function(button, wrapper){
wrapper.scrollIntoView();
var iframe = wrapper.querySelector('iframe#software-embed-frame');
if (iframe) {
iframe.focus();
} else {
if (!wrapper.style) {
document.querySelector('section.post > article').style = 'z-index: 10;';
wrapper.style = 'z-index: 1; position: fixed; top: 0; margin-top: 0; background: black; height: 100vh; left: 0;';
button.textContent = 'Unfocus 🔳️';
} else {
wrapper.style = document.querySelector('section.post > article').style = null;
button.textContent = 'Focus 🔳️';
}
}
}) + ' ' : '') +
(picks.all || picks.fullscreen ? makeButton('Fullscreen 🖼️', function(button, wrapper){
wrapper.querySelector('iframe#software-embed-frame').requestFullscreen();
}) + ' ' : '') +
(picks.all || picks.enlarge ? makeButton('Enlarge ↔️', function(){ document.body.classList[
!document.body.className.split(' ').includes('cinema-view') ? 'add' : 'remove'
]('cinema-view');
});

function diyEmbedHtml (frameUrl) { return (
button('Focus 🔳️', function(ctx){
ctx.parentElement.scrollIntoView();
ctx.parentElement.querySelector('iframe#software-embed-frame').focus();
}) + ' ' +
button('Fullscreen 🖼️', function(ctx){
ctx.parentElement.querySelector('iframe#software-embed-frame').requestFullscreen();
}) + ' ' +
buttonEnlarge + ' ' +
button('Reload ♻️', function(ctx){
var frame = ctx.parentElement.querySelector('iframe#software-embed-frame');
]('cinema-view') }) + ' ' : '') +
(picks.all || picks.reload ? makeButton('Reload ♻️', function(button, wrapper){
var frame = wrapper.querySelector('iframe#software-embed-frame');
var src = frame.src;
frame.src = '';
frame.src = src;
}) + ' ' +
}) + ' ' : '') + '</span>'
) }

function diyEmbedHtml (frameUrl) { return (controlsHtml({ all: true }) +
`<iframe id="software-embed-frame" class="software-embed-frame" src="${frameUrl}"></iframe>`
) }

Expand All @@ -48,8 +59,9 @@ if (platform === 'web') {
window.EJS_core = (core || platform);
window.EJS_gameUrl = romUrl;
window.EJS_screenRecording = { videoBitrate: 150000000 };
thisElement.parentElement.appendChild(SMG.Util.elementFromHtml(buttonEnlarge));
thisElement.parentElement.appendChild(SMG.Util.elementFromHtml(controlsHtml({ focus: true, enlarge: true })));
thisElement.parentElement.appendChild(SMG.Util.makeElement('div', {
className: 'software-embed-container',
style: 'width: 640px; height: 480px; max-width: 100%;',
innerHTML: '<div id="software-embed-frame"></div>',
}));
Expand Down
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit 0419838

Please sign in to comment.