From 0a34567f66a9b6bf6c0baccdad25db6b9d8b6891 Mon Sep 17 00:00:00 2001 From: aws404 Date: Sat, 20 Jan 2024 15:16:48 +1100 Subject: [PATCH] readme and icon --- README.md | 60 ++++++++++++++++-- .../resources/assets/controlifywynn/icon.png | Bin 0 -> 25712 bytes 2 files changed, 56 insertions(+), 4 deletions(-) create mode 100644 src/main/resources/assets/controlifywynn/icon.png diff --git a/README.md b/README.md index fd96346..924acaa 100644 --- a/README.md +++ b/README.md @@ -1,9 +1,61 @@ -# Fabric Example Mod +# Controlify Wynn -## Setup +> Have you ever wondered what it would be like to play Wynncraft with a controller? -For setup instructions please see the [fabric wiki page](https://fabricmc.net/wiki/tutorial:setup) that relates to the IDE that you are using. +Controllify Wynn aims to make it easy to play Wynncraft with a controller. +It not only adds [Controlify](https://modrinth.com/mod/controlify) compatability to [Wynntils](https://modrinth.com/mod/wynntils), but also adds some other nice-to-haves such as additional keybinds (such as a quick Blacksmith sell or Identify) and visual guides (such as the Gathering keybind guide). + +## Full Feature List + +- Controlify/Wynntils compatability: + - Allow binding Wynntils keybinds with Controlify + - Enable better Wynntils GUI navigation with controllers +- New keybinds to help with controller usage: + - Identify/Sell/Scrap Items (inside Identifer/Blacksmith GUI) - GUI Abstract Action 1 + - Page/Scroll Navigation (inside Trade Market/Bank/Ability Tree/Default Quest Book) +- Contoller gathering button guide + +## Mod Dependencies/Requirements + +- Minecraft: `1.20.2` (Required for Wynntils) +- [Fabric API](https://modrinth.com/mod/fabric-api) +- [Wynntils](https://modrinth.com/mod/wynntils) +- [Controlify](https://modrinth.com/mod/controlify) + +## Suggested Configuration + +Through playing Wynncraft with an Xbox controller, this is the configuration that works for me (and is by no means a requrement, you do you!). + +- Movement: Controlify defaults +- Gameplay: + - Drop Item/Stack: Unbound + - Change Perspective: Unbound + - Pick Block: Unbound +- Inventory: + - Drop Item: Unbound + - Swap Hands: Unbound +- Miscellaneous: Controlify defaults +- GUI: Controlify defaults +- Radial Menu: + - Binds: + - Drop Item + - Open Quest Book + - Toggle Gammabright + - Open Main Menu + - Open Main Map + - Cast Spells/Custom Keybinds +- Virtual Mouse: + - Toggle Virtual Mouse: Unbound +- Wynntils: + - Mount Horse: DPad Left + - Cast 1st Spell: X + - Open Main Map: Share Button + +## WIP/Upcomming Features + +- Improved Wynntils GUI navigation +- Imporved Wynncraft GUI navigation and usage ## License -This template is available under the CC0 license. Feel free to learn from it and incorporate it in your own projects. +Controlify Wynn is licensed under the license GNU Lesser General Public License v3.0 diff --git a/src/main/resources/assets/controlifywynn/icon.png b/src/main/resources/assets/controlifywynn/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..1197485f19e4b5895ba7ef6da7a30085c6e36813 GIT binary patch literal 25712 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 literal 0 HcmV?d00001