Skip to content

Elden Bong - daft game ideas engine using electron, three-js, and what-have-you

Notifications You must be signed in to change notification settings

msemtd/elden-bong

Repository files navigation

Elden Bong

This is a project just for fun - not a real game!

  • I want my own Elden Ring map for strategy planning - with all the publicly available info about items.
  • I want a little funny character editor
  • I want a platform to develop my puns, crazy ideas, and art.
  • Parody game data in bongData structure for customisation
  • for merging a number of seemingly unrelated projects with a common app framework that is hopefully pleasing - see MINI-GAMES below for detail

REQUIREMENTS

basic scene

Settings

Persistent user settings: -

  • js-yaml - since easily accessed from the renderer process via LocalStorage
  • map configurations to live here

character

Controls

When a game controller is plugged in (and a button pressed - as per Web API for controllers)...

  • the controller is added to the list of controllers and configured if a config has been saved for it
  • many controllers required including duplicates of the same model
  • find some unique identifier for a controller
  • save the settings for a controller
  • controller button and axis mappings format in JSON (and therefore YAML)
  • TODO game controller input translation is a bit broken - why are the game controls not just perfect?
  • on-screen display of the controller - SVG controller diagram with buttons is working nicely - need to animate joysticks too
  • deal with noise and the dead zone
  • controls on different platforms - https://vulkk.com/2022/02/26/elden-ring-pc-and-console-controls-guide-and-lists/
  • character-based controls versus free-world controls (like quake no-clip) vs map-based controls

'''HTML

ActionPC DefaultsChange to
Movement Speed ControlALTZ
Move ForwardsW
Move BackwardsS
Move LeftA
Move RightD
Backstep / Dodge Roll / DashSPACEALT
JumpFSPACE
Crouch / Stand UpXC
Move Camera / Change Target (Up)SHIFT+↑
Move Camera / Change Target (Down)SHIFT+↓
Move Camera / Change Target (Left)SHIFT+←
Move Camera / Change Target (Right)SHIIFT+→
Reset Camera / Lock-On / Remove TargetQ / MMB
Switch Sorcery / Incantation1
Switch Item2
Switch Right-Hand Armament→ / SHIFT+SCROLL↑3
Switch Left-Hand Armament← / SHIFT+SCROLL↓4
Attack (RH & 2H Armament)LMB
Strong Attack (LH Armament)SHIFT+LMB
GuardRMB
SkillSHIFT+RMB
Use ItemR
Event Action (Talk, Examine, Open etc)E
MapG
Switch RH 1H & 2HE+LMB
Switch LH 1H & 2HE+RMB
SprintHold SPACE
'''

Maps

Map mode and game mode - change scene to be drawn and camera - controls will be different too!

mapScene, mapCamera

keyboard "G"

Nice 2D maps with icons to at least compliment and perhaps rival the existing web-based offerings

Map imports - technical

@ECHO OFF
SET PATH=C:\Program Files\ImageMagick-7.1.1-Q16-HDRI;%PATH%
REM ~ magick identify *.png
REM ~ m0-overworld.png PNG 9728x9216 9728x9216+0+0 8-bit sRGB 172.44MiB 0.000u 0:00.000
REM ~ m1-underground.png PNG 9728x9216 9728x9216+0+0 8-bit sRGB 32.4026MiB 0.000u 0:00.000
REM 256 pixel tiles
REM https://imagemagick.org/Usage/crop/
magick m0-overworld.png -crop 256x256 map-0-overworld-tile256-%%04d.png
magick m1-underground.png -crop 256x256 map-1-underground-tile256-%%04d.png
REM ~ 9728 / 256 = 38
REM ~ 9216 / 256 = 36
REM so we have 38 tiles wide and 36 tiles high
DIR
  • this creates 256 pixel square tiles with names sequentially numbered from top left to bottom right
  • I would prefer these named with the X-Y coordinates - this can be done in a background process
  • scale and position three-js textured cube mesh objects as map tiles
  • the tiles can be used as textures in three-js in the electron renderer process with full security as long as we jump through a number of hoops...

Map texture (and other) local file URLs need to go through the electron net module custom URL protocol

  • mine://maps/(full file path? maybe munge the drive name?)

The maps when imported need some metadata which can be used for reloading: -

  • simple JSON file - can go in LocalStorage or YAML settings
  • user can dereference the maps, clean up the tiles, slice the big maps etc.

Load a JSON map metadata file: -

placing items on the map! getting all the resources! icons and info map overlays and strategy planning stuff - routes, times, stopwatch, etc.

  • downloading the resource pack
  • unpacking the resource pack
  • resource pack dir

my own map definition files

save map to a GLTF or similar

great game assets that are CC0 for including https://polyhaven.com/

map-based controls could do with switching when in map mode camera controls

resources for item id decoding

/~https://github.com/Deskete/EldenRingResources/blob/main/ITEM%20IDS%20Elden%20Ring.txt https://docs.google.com/spreadsheets/d/1evpDLAfi1b3cYfGilDtMWXDvynwyN_lbX1chnSSR7Uk/edit#gid=1201397359 /~https://github.com/MaxTheMiracle/Dark-Souls-3-Parts-Files/blob/master/Elden%20Ring

db creator methods

/~https://github.com/The-Grand-Archives/Elden-Ring-CT-TGA

Elden Ring - Master Spreadsheet https://docs.google.com/spreadsheets/d/1c7rIV3bBKDxP9ngixgigd7ZmczH3DYhDmMt8HY4ijV0/edit#gid=242218508

Looks useful - maybe some standard here? Want IDs to be a close to the game dev as possible

Hexinton https://discord.com/channels/934340237914689536/947960108820860948 https://docs.google.com/spreadsheets/u/3/d/e/2PACX-1vQ0LUsF2rBNa55jMq8KNVYFeyxnV_TinvJ9-xh6nzeWhp3OOnPYu_yNCslI2yorP7hFl47Bel4YE82G/pubhtml#

importing methods describe in docs resource files and directories drag in a file or dir and add to a feature

Map Items

For my maps I'd like the data that the wiki has. I've scraped some data from Chrome dev tools and it has positions in some coordinate system. I assume these coordinates are linear and should map to my map images with a simple transform of scale and offset. I can define the transform from wiki map coord to pixel coord by positioning some sites of grace.

load the items list scrape into an array of strings

527-Stormhill Shack

Development

From scratch (Friday November 04 2022)...

yarn create electron-app elden-bong --template=webpack
cd elden-bong
yarn add -D webpack copy-webpack-plugin
# add eslint - I want a configurable lint based on Standard JS (as recommended by eslint-config-standard)
yarn add -D eslint eslint-config-standard eslint-plugin-promise eslint-plugin-import eslint-plugin-n
yarn add three camera-controls jquery js-yaml jbox fs-extra path-browserify debug

The above can also be used to upgrade the app platform: create a new empty app and compare the results with the current app.

  • upgraded electron-forge and electron, started using preload, context isolation, sandboxing, etc. properly.
  • worked out how to load files with a custom URL protocol (what a drag that was!) Still not worked out how to get the data into three-js loaders - for now reading file data into buffers in the main thread and passing through the preload API

Electron

What it gives: -

  • Native executables for supported platforms distributable as installers. The challenges it introduces: -
  • comply with all the latest electron security restrictions
  • no node in renderer
  • context isolation
  • CSP - clues: https://web.dev/csp/#if-you-absolutely-must-use-it
  • preload creates a context bridge for main-renderer thread comms
  • custom protocol for local file access
  • sub process error stderr in main thread needs to get back to renderer thread - DONE in awaitableSubProcess

Basic Desktop App Needs

  • settings, menus, dialog boxes
  • lit-gui for rough test-mode menu
  • not going down the React route for now though I am enjoying Van-JS!
  • jBox for dialog boxes
  • YAML for settings

MINI-GAMES

As a container for little game and app ideas!

Why maintain multiple repos for projects that nobody else cares about? Hmmm, my goal is to evolve a convenient and enjoyable platform for mostly 3D desktop applications. I can just bundle all my other throwaway junk apps in here and use this app as a vehicle.

  • pitrain-node
  • Kanjifun
  • cards-dude
  • moan-swooper
  • 2048
  • Suica Game
  • Tetris

2D game mode with "mostly" fixed camera - allow user to choose a nice camera position (relative to gameplay board) and save it in a list of favourites. Pause and resume of sub-games. Maybe tie into the Elden Bong narrative and use them as side-quests!

Mini-game chooser or games room "Let's Play Moan-Swooper!" ...back to main game

Cards Dude

Card design database

Type of Playing Card Size (width x Height) Required Bleed Recommended Margin Rounded Corner Size
Standard (Poker) 2.5in x 3.5in 2mm 5mm 3.5mm
Bridge (Slim) 2.25in x 3.5in 2mm 5mm 3.5mm
Tarot 2.75in x 4.75in 2mm 5mm 6mm
Large 3.5in x 5.75in 2mm 5mm 6mm
MTG (Magic Gathering) 2.5in x 3.5in 2mm 5mm 3.5mm

"Playing card thickness varies widely across types. For simplicity, let’s focus on standard playing cards, typically printed on 14pt silk with laminate on both sides. The thickness of a standard playing card is 0.2mm."

Layout based on game (from card game data) and user spacing preferences

TEST BED FOR CRAZY IDEAS

LICENSES AND ATTRIBUTION

Many thanks to the many contributors to the many open source libraries and artworks used in this software. Quite especially...

Sky/Cloud boxes created by Zachery "skiingpenguins" Slocum (freezurbern@gmail.com) http://www.freezurbern.com Content released under the Creative Commons Attribution-ShareAlike? 3.0 Unported License. http://creativecommons.org/licenses/by-sa/3.0/

Grass Texture https://opengameart.org/node/9710

About

Elden Bong - daft game ideas engine using electron, three-js, and what-have-you

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages