v0_8 29 May 2024
- Start Area
- Actors
- Course Area
- Instructions
- Functions
- Resource Pack
- Puzzle Functionality
- Making a Puzzle
- Puzzle Wand
- Dev Book
- Cloning
BarreblBot is an innovative learning bot created on Minecraft: Java Edition that helps users learn basic fundamentals of programming. The bot is mainly targeted towards children to be used as an introductory tool that integrates gaming with learning. Minecraft: Java Edition was chosen as the base platform due to its world wide popularity and its ease of use for children.
BarrelBots aligns with the fundamental goals of a programming system, especially in regards to supporting and encouraging new ways of thinking and enabling programmers to see and understand the execution of their programs. Through the platform, users are able to test out different sets of programming instructions in order to solve and then create their own puzzles. Furthermore, the Barrelbot displays the programming instructions as it moves throughout a task, which allows users to visualize the fruits of their work. They are pushed to think outside the box on how to apply what they know and have learned to future programming work.
Start Button:
Used to activate and deactivate the puzzles. Simply click the start button in order to activate the puzzle at which time the overhead display should change from "start" to "reset". Click the button again to reset the puzzle. Appears when a puzzle is created.
Hopper:
Low capacity storage block that appears as part of the puzzle creation. It automatically collects any items directly above it.
Shulker Box:
Higher capacity storage block appears as part of the puzzle creation. Main usage is to store instructions that users can collect to complete the puzzle.
BarrelBot:
Innovative learning bot created to allow users to visualize and understand programming fundamentals. The Bot stores instructions the users places into it and then executes them once the puzzle is run.
Creation/Deletion:
- Created with Features > Spawn Bot in dev book. It can also now be used as a block that can be placed.
- Will face the way that you were facing when you spawn it
- Make sure you are not standing directly over the run button when you spawn the bot or it will spawn over the button
- To delete the barrelbot, simply destroy the block or click Features > Delete Bot
Dispenser Bot:
Another type of bot that is an extension of a barrelbot. It is mainly used in the puzzles as "enemies" that users have to avoid in their completion of the puzzle. The bot stores instruction blocks that it executes, but these instructions are locked into the bot unless it is manually converted back to a barrelbot first.
Creation/Deletion:
- First, create a barrelbot and load in it any instructions you want the dispenser bot to have
- Once you’ve set it up, stand near it and click Features > Convert to Dispenser
- To make changes, go to Features > Convert to Barrel, make any changes you would like, then convert it back to a dispenser bot
- Destroyed the same way as barrel bots
Puzzle courses are either designed to have users a) solve the puzzle by following a specific path outlined by course blocks or b) give users the freedom to choose how to have their barrelbot move as long as it reaches the success condition.
These are the actual commands the barrelbots execute, and you can give them to yourself in the Instructions tab of the dev book
Most instructions can be acquired without any configuration. These include:
- Move forward
- Move down
- Turn left
- Turn right
- End code block
- Infinite loop
Some instructions require further specifications. They will copy the instruction command to your clipboard, which you will then have to paste in chat and configure by adding text to the command.
These configurable instructions include:
- If statements
- the instruction command contains two parts: {condition: " ", description: " "}.
- {condition:” ”}
- this is the condition that the if statement checks for. It is formatted in the same way that the
execute if
subcommand is - Example: To check if the block ahead is air, you would insert “
if block ^ ^ ^1 air
” into the condition quotation marks - Coordinate guide (these all the characters to place into the condition):
- Forward: ^ ^ ^1
- Backwards: ^ ^ ^-1
- Left: ^1 ^ ^
- Right: ^-1 ^ ^
- Up: ~ ~1 ~
- Down: ~ ~-1 ~
- for more information about minecraft coordinates
- this is the condition that the if statement checks for. It is formatted in the same way that the
- {description:” “}
- The text that shows in the tooltip of the item
- Just formatted plain text
- Make sure to use an end block to end the if statement
- Counter Loops
- {cycles: }
- Number of times to repeat the loop
- {cycles: }
- While loops
- Configurations the same as If statements
Spawns as container block with a message saying "click to link function item"
You can link a function item by either clicking on the block with the item in your hand or by standing near the function you want to link it to and clicking Features > Link Function Item. In order to link an item to the function, you must rename it, ideally with details as to what the function does, first.
You can then place instructions into the function to describe what you would like it to do.
Once this is done, you can place the function item in a barrelbot in order to represent your function and have it execute the function instructions.
Functions can be pre-set and locked by placing a honeycomb onto the function block. To unlock it, click honeycomb again.
The resource pack is a folder on the backend that holds all the custom textures/models/other assets used for barrelbots. Examples of what is held in the resource pack include the face of the barrel bot or the icons for the instructions.
- First retrieve the instructions from the shulker box at the start of the puzzle or create your own using the dev book
- Place the necessary instructions into the barrelbot that allow you to complete the puzzle (you reach the success condition)
- Click the start button to run the puzzle and watch the barrelbot execute the instructions you gave it
- To reset the puzzle, click the start button again and this will cause the barrelbot to return to its initial position where you can change any of the instructions if necessary
Creating a puzzle:
All puzzles are defined by a primary puzzle entity, which is located at the puzzle’s activation button. To create a puzzle, open your dev book and click:
Puzzle > Create Puzzle
If there is not already a button there, this will create the button and puzzle entity at your feet. You can break and replace this button without deleting the puzzle, and any button type will work.
Linking to a puzzle:
Whenever you’re editing a puzzle, you should always link yourself to the puzzle that you’re working on. This will ensure that any bots you spawn are linked to that puzzle and will activate when you press the corresponding button. You can do this with:
Puzzle > Link to Puzzle
You will also automatically link to a puzzle when you spawn it.
Deleting a puzzle:
To delete a puzzle, simply destroy the puzzle blocks
Resetting all puzzles:
You can reset all puzzles using Puzzle > Reset all puzzles.
This will stop any puzzles that were left running and restore a puzzle’s item box to its original state.
Seeing and changing boundaries:
Boundaries are set by placing light blocks with a light level of 0. When a player touches one of these blocks, any puzzle-bound items in their inventory will be transported back to their appropriate puzzle.
Adding in barrelbots and dispenser bots:
To add a barrelbot or dispenser bot to the puzzle, make sure you are first linked to the puzzle or in the puzzle boundry (which automatically will cause the barrelbot to link to the puzzle). Then simply place the barrelbot/dispenser bot as specified above, and it will then be automatically linked to the puzzle.
Attaching instructions to a puzzle/Setting Puzzle Itemse:
If you want to restrict a puzzle to only allow a specific set of items or add instructions to a puzzle, you can do the following:
- Keep track of which direction you were facing when you spawned the puzzle (you can check this by pressing f3+b, and a blue line will appear facing the direction the puzzle entity is facing
- Put a yellow shulker box (or other container block) 1 block behind and 1 block below the puzzle
- Place a hopper to the left of the shulker box facing it
- Place any items you want the puzzle to have in the shulker box
- Click Puzzle > Set Puzzle Items
These items are now bound to a puzzle. If a player in survival mode tries to take items out of the boundaries of the puzzle, they will get transported back to the hopper and filtered back into the shulker box.
Customized instructions:
to be added
Success conditions:
The puzzle manager is coded to have configurable success conditions, so we can have different ways of measuring whether a puzzle is “complete”, like having all barrel bots land on a green space, or delivering a cake to a certain location.
To set a puzzle’s success condition, stand near it and click Puzzle > Set Success Condition. Paste the command into chat, and replace the “”
at the end with the success condition’s name.
Currently, there is only one success condition:
touch\_green
Puzzle is successful if all bots are standing on a green space
[Technical] Adding a New Success Condition:
- Navigate to the success conditions folder
- data > whimc > functions > barrelbot > success_conditions
- Create a new function file
- The name of the function is the id of the success condition
- Ex: deliver_cake.mcfunction
- Program success condition
- Your function communicates by editing the scoreboard player
$success whimc.dummy
scoreboard players set $success whimc.dummy 1
communicates successscoreboard players set $success whimc.dummy 0
communicates failure
- Your function communicates by editing the scoreboard player
note: the wand is still a work in progress, but the goal is to have it completely replace the dev book
The wand allows you to tinker with the features of a puzzle. Simply right click while holding the wand to scan for an editable feature. If an editable feature is found, it will bring up an editing menu. To exit this menu, press the left shift button or crouch. You need to be out of interaction range with objects that you can open or press.
Command: /loot give @s loot whimc:edit_wand
note: if the @s gives a "selector not allowed" error, replace it with your username
List of Editable Features in the Wand and How They Can be Edited (WIP):
Swap dispenser/barrel: converts the barrelbot between barrel and dispenser form. Dispensers have their items locked and are meant to be part of the puzzle ratehr than something to interface/work with directly.
Scanning a puzzle button will automatically link you to that puzzle. The puzzle you’re linked to will show a purple indicator over it whenever you’re holding an edit wand.
Toggle size editor: allows you to edit the size of the puzzle. Use the puzzle wand on the start button and click on the yellow stained glass pane that appears (see image above). This will display a yellow boundry. Right click and drag the yellow block that appears to change the size of the puzzle boundry.
Propagate changes: any changes made to this puzzle will be copied over to any clones of the puzzle as well. This feature is currnetly indicated by an orange stained glass pane.
Puzzle Button: /function whimc:barrelbot/block/puzzle_button/give
Barrelbot: /function whimc:barrelbot/block/barrelbot/give
Function: /function whimc:barrelbot/block/function/give
The dev book allows access to all developer functions. To give yourself the dev book, type the following command chat:
/function whimc:barrelbot/dev/give_dev_book
note: still in the process of being transferred to the wand
Basic Clone: Clone the puzzle you are currently linked to by going to the dev book Clone page and selecting start clone. You can create the new clone puzzle by selecting Clone > Paste Puzzle.
Cascade Clone: Creates a 2-dimensional array of clones of the puzzle you are currently linked to. To perform a cascade clone:
- Link to a puzzle by selecting it with a puzzle wand
- In the dev book, select clone > cascade clone. This will bring up a menu
- Specify the dimensions of the array in the x and z direction (negative numbers will paste that many clones in the negative x/z direction)
- Specify the spacing between puzzles in the x/z direction
- Click "paste" (note: preview button does not currently do anything)