this post was submitted on 16 Jul 2023
1 points (100.0% liked)

Minecraft Suggestions

0 readers
1 users here now

The official unofficial magazine for discussing Minecraft ideas! Counterpart of /r/minecraftsuggestions on Reddit. ### Important Links _**Expanded Rules**_ _**Frequently Posted Suggestions (FPS)**_ _**MCS Discord Server**_ ### Rules 1 | Be nice and constructive. 2 | Speak English. 3 | Only post ideas for Minecraft. 4 | Be original and consult the FPS list. 5 | Don't include multiple independent ideas in one post. 6 | Be concise but specific. 7 | Don't suggest planned or existing features (including parity). 8 | Don't suggest scrapped or unused features without significant reworks. 9 | Don't suggest jokes, easter eggs, or overly unrealistic ideas.

founded 2 years ago
 

Introduction

Throughout the years, I've seen many posts suggesting that "dispensers should use X item on Y mob/block" and some functionality has been added already, like using shears on sheep.

However, what dispensers can and can't use is somewhat arbitrary: dispensers can shear sheep yet can't take water from a cauldron.

To a new player, there's no way to know which items can be used by a dispenser except by trial and error.

New Player: "Oh, dispensers can wax copper blocks? Surely they can also unwax/deoxidise them if I put an axe in them, right?"

Narrator: "They can't."

In my opinion, dispensers should be able to use any item with a right-click use.

The Suggestion

In order to make dispensers more intuitive and turn them into a general "item user" (as opposed to just a slightly more expensive dropper except in some cases), I came up with a simple algorithm for determining what a dispenser should do with an item.

While some initial bugs are to be expected, this is more maintainable than the current code, which has the current uses hardcoded and must be expanded each time a new use is added, i.e. something that should be avoided when possible.

Below is the pseudocode for an hypothetical function that gets called when a dispenser is activated and should use/dispense an item:

if item has use: # can be right-clicked
    if item is projectile: # more accurately, summons a projectile entity
        shoot projectile entity
        return
    if item targets user: # when the item is used on the player who uses it, like armour
        if has valid target:
            try using as entity # behaves like the entity used the item
            return
    if item targets an entity: # when an item is used by right-clicking an entity, like shears on sheep
        if has valid target:
            try using item on target
            return
    if item targets block: # when an item is used on a block, like a shovel on dirt
        try using on block in front
        return
    if item is placeable: # places a block or entity
        try placing in front
else:
    drop item

If you don't understand what anything of this means, I'm happy to clarify, just leave a comment.

The way this works is: pick an item, follow the structure of the code and stop when you reach a return or the end.

For example, a pumpkin would be equipped on a mob (like a zombie) if one is on front, otherwise places the pumpkin.

Some things to note

  • One of Mojang's concerns with this is straying from their design principle about not automating everything. However, we already have quite a bit of automation and some new uses for dispensers are already automatable via other means (like villagers). I believe this still adheres to that principle while allowing a reasonable level of automation.

  • I included placing blocks, since I don't think that would be a problem. Dispensers can already place water and lava, which can flow and create many blocks. This is especially true in Java Edition, where dispensers aren't movable by pistons.

  • There are many items with many different functions, so there may be some type of item I forgot to account for or something where the resulting behaviour may be undesired. As such, I'd like you to choose an item and follow the pseudocode and tell me if you find any situation that would be undesirable.


Tell me what cool things could be done if this was implemented.

no comments (yet)
sorted by: hot top controversial new old
there doesn't seem to be anything here