Skip to content

WsdfR/PhoenixBuilder

Repository files navigation

FastBuilder Phoenix

Description

FastBuilder is a structure generating tool for Minecraft Bedrock Edition that supporting various platforms. The Phoenix ver. was designed for the rental server of the Minecraft China Edition. Currently supports generating Euclid geometry and ACME(mcacblock) · schematic file(NBT data of blocks would be disposed)'s structures, and images painting.

NOTE: FastBuilder Phoenix is a commercial software!

Principle

FastBuilder currently using an all-new technology, and no longer limited by the WebSocket. Thanks to it, the all-new FastBuilder's speed, performance and stability got a significant improvement, and it became highly extendable. The core of the current version of FastBuilder is based on Sandertv's Gophertunnel project that licensed under the MIT License.

Open Source

FastBuilder Phoenix is currently partially opened source (the user center's authentication system and some of the core algorithms are not included), source code available here.

(The source code is licensed under GPL v3.)

Acknowledgements (Read before purchasing)

  • The technology that it uses may expire any time, so FastBuilder life-time support is not guaranteed.
  • The version of FastBuilder you bought contains the features explained above, we may add other features in the future but we can't guarantee to that.
  • Some steps of the installation and the use of FastBuilder needs a certain degree of IT and Math knowledges, and the instruction for installation would consider that you have these required knowledges by default.
  • FastBuilder personal account can only be binded to at most two rental servers, and it allows to be changed once per month. FastBuilder Phoenix can't be used in multi-player mode of NEMC or in the international version of Minecraft.
  • Please do not import any files without the author's permission, every single content creator survives in the community with their own energy and wisdom. Using others' IP (stands for Intellectual Property) commercially would cause destructions to the whole environment of the game. Moreover, if the copyright owner of contents you have used ascertains the liability, you should and must take your responsibility, and we shouldn't bear any liability for it.
  • Developers aren't customer service reps, they don't have the obligation to resolve the various problems you met when using the software, moreover they would not guide you to install the software by themselves. If you found bugs when using the software and you are very sure of it, you can submit bug reports to a seller.
  • The current version (Phoenix Alpha) is under testing, various bugs might be triggered, purchasing means you volunteer to bear the risks.
  • The nearly full-English prompts in the program doesn't mean that we are not Chinese.
  • We designed every feature as perfect as possible, but it still contains defects.

World View

The differences between FastBuilder and other programs is that it contains the concept of "server" and "client". The game that players running is a client, FastBuilder is also a client, and the rental server the player enters is a server.

Therefore, clients can run on different devices, and FastBuilder can be executed to join your server w/o your game running.

The abilities explained below are required since FastBuilder needs the operations of command lines.

  • The ability of operating files: Able to understand the level of paths and files.
  • The ability of reading English: Able to identity words like "Error", "Permission denied" or "Not found" and know what they stands for.
  • The ability to differ the full-width and the half-width characters.
  • It's better to have the ability to enter and execute commands in the command line interface.

Please ensure that you have the abilities mentioned above, if you encountered problems when using FastBuilder because you are not satisfying the mentioned conditions, development group would not bear any liabilities, moreover it will not provide any help.

Installation Instruction

Requirements

  • Holds a FastBuilder User Center account, aka a FastBuilder account (bought FastBuilder).
  • Depends on your device:
    • PC (Windows/Linux/macOS): Your computer should have a fully functional network adapter installed.
    • Android: Have Termux installed, see below for instruction.
    • iOS: Jailbroken, and you know how to use the terminal.
  • Hard-working hands and thoughtful brain
  1. Login to FastBuilder User Center
  2. Click the Profile tab, and set the Minecraft China Edition Username(中国版用户名).
  3. Enter the number of the rental server(租赁服) that you want to use FastBuilder on.(note: The rental server should accept the entrance of any level(等级)'s player, satisfy it by turning off "player entrance level requirement(玩家等级准入要求)" toggle in the server settings interface)
  4. Set a nickname of the helper user(辅助用户), then click [Create(生成)] to create one.

That's all for the completion of necessary informations, and the following content is the steps of installation, different platforms have different solutions, please find your own platform:

Steps for Installation

  • Windows: Download directly in the [Download] tab of the user center.

  • iOS: Install the package from our APT package source.

  • Linux x86_64 (recommended platform):

    wget -O fastbuilder https://fastbuilder.pro/downloads/phoenix/phoenixbuilder
    chmod +x fastbuilder
  • Android:

    • a. Click here to install Termux (0.117); (Or download it from a trustable source by yourself.)

    • b. After the installation of Termux, navigate to your system configuration, and give it the permission of accessing the storage space (aka sdcard), and allow it to run in the background without limitations.

    • c. Open the Termux application, copy and execute following commands.

      First, use the commands below to replace the official source to the TUNA mirror source (optional, recommended for users in China since it will boost the follow-up steps, users in other countries shouldn't perform this step.)

      WARNING: These 3 commands should be executed in order. The mentioned mirror is only suitable for Android version 7.0 (API 24) and above, the use of this mirror in older versions of system may cause program exceptions. Please do not use this mirror in case of you are using older versions of system.

      sed -i 's@^\(deb.*stable main\)$@#\1\ndeb https://mirrors.tuna.tsinghua.edu.cn/termux/termux-packages-24 stable main@' $PREFIX/etc/apt/sources.list
      sed -i 's@^\(deb.*games stable\)$@#\1\ndeb https://mirrors.tuna.tsinghua.edu.cn/termux/game-packages-24 games stable@' $PREFIX/etc/apt/sources.list.d/game.list
      sed -i 's@^\(deb.*science stable\)$@#\1\ndeb https://mirrors.tuna.tsinghua.edu.cn/termux/science-packages-24 science stable@' $PREFIX/etc/apt/sources.list.d/science.list
    • c. Update sources and packages (REQUIRED) :

      apt update -y
      apt upgrade -y
      apt install wget -y
    • d. After successfully executed commands mentioned above, download the FastBuilder binary.(Replace the arm64 part to armv7 if you surely know that your device is an armv7 device. Note that nowadays armv7 device is seldom. x86 or x86_64 android device are not supported.)

      Note: This step (d) is also the way of upgrading FastBuilder Phoenix, execute this step directly to upgrade FastBuilder afterwards.

      wget -O fastbuilder https://fastbuilder.pro/downloads/phoenix/phoenixbuilder-android-executable-arm64
      chmod +x fastbuilder

Usage

FastBuilder Phoenix is a pure command line program without complicated GUI, which made the program very easy to use.

Launching

  • Windows: Double-click FastBuilder executable(.exe) file to execute.

  • Linux: No need to explain.

  • iOS: Open the terminal and execute the following command:

    fastbuilder
  • Android: Open the Termux app and execute the following command:

    ./fastbuilder

Initialization

If no exceptions happened, after finishing these steps, you will see the FastBuilder's copyright notice and other things. It will ask you to enter your FBUC(FastBuilder User Center) username and password (Password won't be echoed), and you won't need to do that it twice.

Then, FastBuilder will ask you to enter the rental server number and its password(Press Enter directly if none, won't be echoed). If it haven't crashed, presumably it has been launched.

After that, leave it in the background, and enter the rental server. Seeing the helper user is online(in the user list in /list command or in pause interface) means that FastBuilder works properly. Please give the helper user OP(operator) permission. The helper user will only listen to operator's(your) commands, so the the Minecraft China Edition Username should be set to the same to you nickname in Minecraft China Edition. Please do not use skin packs with the title(称号) since the helper user won't be able to process your commands.

FastBuilder Command Resolving

FastBuilder uses a system similar to Linux Shell (it isn't the same command system of Minecraft). The "/" is needless and you can execute it by simply send it as a chat message.

Note that you can't use "#" to give a comment in FastBuilder's commands.

# Example: Generate a round with radius 5, faces the y-axis.
# These 2 commands below do the same thing.
round -r 5 -f y -h 1
round --radius 5 --facing y --height 1
Generator Settings

After initializing FastBuilder, we call the dimension that the helper user(bot) in as a space, every operations would be executed in this space. So if you want to use FastBuilder in a different space, you should teleport the bot to the target space.

To use FastBuilder, you should set the origin of the space(structures will be built around the origin), and the default origin is the position where bot entered the game.

Use get command to modify the origin to the current position of you.

The usage of commands of corresponding features are shown below.

FastBuilder Phoenix used the multi-task system, which means that you can have more than one tasks to be executed at the same time, and you can use the task command to manage tasks.

Task Command

task command was designed for managing the current tasks(building process). Every task has its own runtime, and you can use some functional commands to set the internal arguments for tasks. task command has the following basic child commands(Texts after # are comments, which are used to explain what the child command for):

tasktype <type:async|sync> # **Global command**, set the task type for newly-created tasks. Sync mode doesn't support the progress displaying but builds at the same time of calculating, and async mode supports displaying the progress since it builds after calculation.
task list # Lists the ID of each tasks, and its content · status.
task pause <taskID> # Pauses a specific task
task resume <taskID> # Resumes a specific task
task break <taskID> # Destroys a specific task (Unrecoverable, the task will be gone from the task list)

task command can also be used to set the delay of a task or its delay mode:

task setdelay <taskID> <delay> # Sets the delay for the specified task. The unit in continuous mode is microsecond and it's second in discrete mode.
task setdelaymode <taskID> <delayMode:continuous|discrete|none> # Sets the delay mode for the specified task, there are 3 modes available.
task setdelaythreshold <taskID> <threshold:int> # Sets the threshold for a specific task, only available in discrete mode.
  • continuous: Send packets with a specific speed.

  • discrete: Send packets without delay after wait the time of delay's value (the max count of packets per delay won't be greater than the threshold).

  • none: Send packets continuously without delay.

Each mode has its own advantages and disadvantages, please handle is as you think fit:

  • Speed: continuous <= discrete < none (For some special configurations, continuous mode's speed may faster than discrete mode's speed)
  • Stability: continuous > discrete > none
  • Smoothness: continuous > none >= discrete
Functional Commands
  • Set the origin for the space:

    get
  • Set the global command execution delay solution:

    delay mode <delayMode:continuous|discrete|none> # Sets the default packet sending solution
    delay threshold <threshold:int> # Sets the default threshold, only available in discrete mode.
    delay set <Delay:int> # Sets the default packet sending delay. The unit in continuous mode is microsecond and it's second in discrete mode.
  • Set whether to show the progress (show informations like the percentage of construction, total block count, and the instantaneous velocity. default:true)

    progress <value:bool>
Geometry Commands

FastBuilder has the ability of constructing simple geometry structures in the space. (like round, circle, sphere, line, ellipsoid, etc.)

  • Round/Circle:

    round/circle -r <radius> -f <facing> -h <height> -b <tileName> -d <data>
    -r --radius The radius of the round or circle.
    -f --facing Facing, available values: x,y,z
    -b --block Block to be used to construct the structure
    -d --data The data (aka damage value) of the block to be used to construct the structure
  • Sphere:

    sphere -r <radius> -s <shape>
    -s --shape hollow|solid
  • Ellipse:

    ellipse -l <length> -w <width> -f <facing>
    -l --length Length
    -w --width Width
  • Ellipsoid:

    ellipsoid -l <length> -w <width> -h <height>
Structure Construction Commands

Load and construct structures from schematic, bdx(bdump) or mcacblock(structure file exported by the ACME building tool) files:

schem -p <filePath>
acme -p <filePath>
bdump -p <filePath>
-p --path The path of the file, use "" to assign a path with blankspace(s).
# optional flags: --excludecommands : Exclude commands in command blocks
# 				  --invalidatecommands: Invalidate commands in command blocks by adding characters to the start of the command content, for example, the invalid form of "say 123" is "|say 123".
Painting Slice Construction
  • Load image to the space:

    plot -p <imageFilePath:string> -f <facing:x|y|z>
Experimental: Structure Export

WARNING: This feature is unstable, unexpected things might happen during the use of this feature. Please check whether the exported file is valid since sometimes it might be exported to an invalid format.

  • Set the start point of export

    get

    or

    get begin
    • These are two different forms of a same command.
  • Set the end point of export

    get end
  • Export the structure in assigned area to a file

    export -p <filePath>
    # optional flag: --excludecommands : Exclude commands in command blocks
  • Import the exported file with the command bdump mentioned above.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 97.5%
  • Shell 1.4%
  • Other 1.1%