English | 简体中文
A powerful Spigot/Paper plugin that brings the power of a modern web browser into Minecraft using maps and the Java Chromium Embedded Framework (JCEF).
- Features
- Dependencies
- Installation
- Configuration
- Commands and Permissions
- Building from Source
- License
- Acknowledgements
- Dynamic Browser Creation: Create interactive browser screens of any size, anywhere in the game world.
- Real-time Web Rendering: Based on the Chromium engine, it can render modern web pages, including complex CSS and JavaScript.
- Fully Interactive:
- Interact with web elements via mouse clicks.
- Input text into forms and search boxes using commands.
- Send specific key presses (like Enter, Shift, Backspace) for advanced control using commands.
- Developer Tools: Toggle Chromium Developer Tools in real-time to debug web layouts and performance directly in-game.
- Highly Configurable:
- Enable remote debugging via
config.ymlto connect with Chrome DevTools. - Support for specifying a custom JCEF Bundle path.
- Configure
user-agent, user data path, and custom CEF arguments throughconfig.yml.
- Enable remote debugging via
- MapEngine (Required): This plugin depends on the MapEngine API for map rendering. Please ensure you have installed and enabled MapEngine on your server.
- Download the latest
MapBrowser-*-all.jarfile from the Releases Page. - Ensure you have already installed the MapEngine plugin.
- Place the downloaded
MapBrowser-*-all.jarfile into your server'spluginsdirectory. - Start or restart your server.
- On the first launch,
jcef-mavenwill automatically download and install a custom version of CEF suitable for your server's operating system. Currently, onlyWindows amd64/i386andLinux amd64/arm64are supported. If our custom version is not available, MapBrowser will be disabled automatically. This process may take a few minutes and requires a good network connection. Please be patient and monitor the console logs.
When the plugin loads for the first time, it will create a configuration file at plugins/MapBrowser/config.yml.
# --------------------------------------------------- #
# MapBrowser Configuration #
# --------------------------------------------------- #
jcef:
# Your custom JCEF binaries path (leave blank to disable)
# Default: (plugins)/MapBrowser/jcef-bundle
custom-install-path: ""
# Custom jcef-maven download mirror (for custom-builds)
mirror: "https://github.com/Steve3184/mb_jcefbuild/releases/download/v1/"
# Should jcef-maven check the JCEF binaries at startup?
skip-download: false
browser:
# Should we enable the sound (default is false)
enable-sound: false
# CEF's user data directory
# Default: (plugins)/MapBrowser/userdata
user-data-dir: "userdata"
# CEF's remote debugging
remote-debugging:
enabled: false
# Should we enable it? (default is false)
port: 9222
# Remote Debugging Port (default is 9222)
# CEF's User-Agent
user-agent: ""
# Where should CEF output the log
# 'file' -> write to (plugins)/MapBrowser/cef.log
# 'console' -> write to console
chrome-log-output: "file"
# Extra CEF startup args
custom-chrome-args:
- "--disable-gpu-compositing"
- "--disable-gpu-vsync"| Command | Description | Usage | Permission |
|---|---|---|---|
/mb create |
Creates a new browser screen at the specified location. | /mb create <x> <y> <z> <url> [width] [height] |
mapbrowser.command.create |
/mb list |
Lists all currently active browser screens. | /mb list |
mapbrowser.command.list |
/mb remove |
Removes a specified browser screen. | /mb remove <id> |
mapbrowser.command.remove |
/mb modify |
Modifies the properties of an existing screen. | /mb modify <id> <prop> [values...] |
mapbrowser.command.modify |
├ url |
Changes the URL loaded by the screen. | /mb modify <id> url <new_url> |
|
├ devtools |
Toggles the developer tools on or off. | /mb modify <id> devtools <on|off> |
|
├ pos |
Moves the browser screen. | /mb modify <id> pos <x> <y> <z> |
|
├ size |
Changes the size of the browser screen. | /mb modify <id> size <width> <height> |
|
└ refresh |
Refreshes the browser page. | /mb modify <id> refresh |
|
└ scale |
Setting the scale of browser page. | /mb modify <id> scale <newScale> |
|
/mb input |
Sends text input to the specified screen. | /mb input <id> <text...> |
mapbrowser.command.input |
/mb keys |
Sends a key event to the specified screen. | /mb keys <id> <key> <action> |
mapbrowser.command.keys |
/mb executeJs |
Executes custom JS code or a JS snippet in the specified browser screen. | /mb executeJs <id> <jsCode|snippet.js> |
mapbrowser.command.executejs |
/mb near |
Lists the ID of the nearest browser screen. | /mb near |
mapbrowser.command.near |
Key Actions for /mb keys:
pressDown: Simulates pressing a key down.pressUp: Simulates releasing a key.click: Simulates a full press and release.
If you want to modify or build this plugin yourself:
-
Prerequisites:
- Java Development Kit (JDK) 21 or higher.
- Git
-
Build Steps:
# Clone the repository git clone https://github.com/Steve3184/MapBrowser.git cd MapBrowser # Build the Jar using Gradle ./gradlew shadowJar
-
After a successful build, you can find
MapBrowser-*-all.jarin thebuild/libs/directory.
This project is licensed under the GNU AGPL v3.
You can view the full license here: LICENSE
- MapEngine:
AGPL-3.0-only - JCEF-maven:
Apache-2.0
- pianoman911 - For creating the powerful MapEngine library.
- CinemaMod - For providing convenient JCEF pre-built binaries, which greatly simplifies the integration of CEF with support for codecs like h264.
