Skip to content

Thats-so-Mo/Hogwarts-Legacy-Wand

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

50 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Casting Spells in Hogwarts Legacy (PC Only) with the Kano Wand and a Raspberry Pi Zero W (V1)

The basic idea behind this project is to convert the gestures/movements of the wand into keyboard button presses with the help of a Raspberry Pi Zero W. The wand connects to the RPI Zero W via Bluetooth which then RPI Zero W sends data to the PC with Hogwarts Legacy running on it via USB (usb data port).

Check out the video for a setup process and demonstration

IMAGE ALT TEXT HERE

This uses GammaGames' Kano_wand module/code (https://github.com/GammaGames/kano_wand) and I have a copy of their code/module included within my repository as a way to make it easier for people to clone. He has two repositories dedicated to the kano wand;https://github.com/GammaGames/kano_wand and https://github.com/GammaGames/kano-wand-demos (PLEASE CHECK THEM OUT). Without him, I would not have been possible to actually do this. Special Thanks to him, Jesse Linburg.

I also utilised this tutorial to setup and aided in the creation of my Hogwarts Legacy Wand code, Maspieljr's instructable is what I have followed to help set me up. The tutorial on the instructable is sourced from Jesse Linburg (aka GammaGames) himself. Thanks to Maspieljr!

For the PC to accept commands from a wand, the Raspberry Pi Zero W is turned into a USB HID device, Special Thanks to RandomNerdTutorials for this tutorial

Special Thanks to the Harry Potter Nerds who filled out those wikias with wand movements, without them I wouldn't have know how to do an Accio cast. lol

Down below is just a slightly modified copy of the tutorial found on his Instructable and from the original source material

Gestures

There are the gestures for V1 and V2, both verisons are slightly different but it has the same meaning. There are some missing gestures as I didn't capture all of them but if you are interested in adding your own - have a scroll look through, gesture.py script is your friend.

Some gestures can be found from the Kano Wand Motions sheet:

IMAGE ALT TEXT HERE

KEY:

U = UP

D = Down

L = Left

R = Right

UL = UP LEFT

UR = UP RIGHT

DL = DOWN LEFT

DR = DOWN RIGHT

V1

        ("U", "U"): "lumos"
        ("D", "D"): "nox"
        ("DL", "R", "DL"): "stupefy"
        ("DR", "R", "UR", "D"): "wingardium_leviosa"
        ("DR", "R", "U"): "levioso"
        ("UL", "UR"): "reducio"
        ("DR", "U", "UR", "DR", "UR"): "flipendo"
        ("R", "D"): "expelliarmus"
        ("UR", "DR", "L"): "incendio"
        ("U", "D", "DR", "R", "L"): "locomotor"
        ("DR", "DL"): "engorgio"
        ("UR", "R", "DR"): "aguamenti"
        ("UR", "R", "DR", "UR", "R", "DR"): "avis"
        ("D", "R", "U"): "reducto"
        ("DR", "R", "UR", "UL", "UR", "R", "DR"): "reparo"
        ("DR", "R", "UR", "U", "UL"): "reparo"
        ("DR", "R", "UR", "UL", "L", "R"): "reparo"
        ("DR", "R", "UR", "UL", "UR", "R"): "reparo"
        ("DR", "R", "UR", "UL", "L", "UL", "R"): "reparo"
        ("DR", "R", "UR", "UL", "R", "DR"): "reparo"
        ("DR", "R", "UL", "L", "R", "D"): "reparo"
        ("U", "DR", "DL", "DR"): "revelio"
        ("DR", "UR"): "protego"
        ("UR", "R", "DR"): "accio"
        ("DR", "U", "DL"): "ancient"
        ("R", "L"): "basic"
        ("L", "R"): "basic"
        ("U", "DL", "U"): "changespells"
        ("UR", "R", "DR", "DL", "L", "UL", "UR", "R", "DR", "DL"): "disillusionment"
        ("R", "DL", "R"): "ancient_throw"

V2

        ("U", "U"): "lumos"
        ("D", "D"): "nox"
        ("DL", "R", "DL"): "stupefy"
        ("DR", "R", "UR", "D"): "wingardium_leviosa"
        ("DR", "R", "U"): "levioso"
        ("UL", "UR"): "reducio"
        ("DR", "U", "UR", "DR", "UR"): "flipendo"
        ("R", "D"): "expelliarmus"
        ("UR", "DR", "L"): "incendio"
        ("U", "D", "DR", "R", "L"): "locomotor"
        ("DR", "DL"): "engorgio"
        ("UR", "R", "DR"): "aguamenti"
        ("UR", "R", "DR", "UR", "R", "DR"): "avis"
        ("D", "R", "U"): "reducto"
        ("DL", "UR", "DL"): "avada_kedavra"
        ("DR", "R", "UR", "U", "UL"): "reparo"
        ("UR", "R", "DR", "UR", "R", "DR"): "conjuring_spell"
        ("DR", "R", "UR"): "depulso"
        ("UR", "DR", "UR", "UR", "D", "DR", "DL", "L"): "glacius"
        ("U", "UL", "L", "DL", "D", "DR", "R"): "descendo"
        ("DR", "R", "UL", "L", "R", "D"): "reparo"
        ("UR", "L", "DR", "L"): "crucio"         
        ("U", "DR", "DL", "DR"): "revelio"
        ("DR", "UR"): "protego"
        ("UR", "R", "DR"): "accio"
        ("DR", "U", "DL"): "ancient"
        ("R", "L"): "basic"
        ("L", "R"): "basic"
        ("U", "DL", "U"): "changespells",
        ("UR", "R", "DR", "DL", "L", "UL", "UR", "R", "DR", "DL"): "disillusionment"
        ("R", "DL", "R"): "ancient_throw"

First thing: SETUP the RPI for Hogwarts Legacy Wand (Kano Wand).

I essentially set up my RPI to be headless (You can find tutorials online for this). Found below, is the slightly modified verison of the tutorial, slightly more update to date.

**Step 1: RPI OS installed on Raspberry Pi**

Once you've completed the install, Run the two bottom commands in terminal to ensure RPI is update to date.

> sudo apt-get update

> sudo apt-get upgrade


**Step 2: Install Python 3**

Python3 should already be installed. But just incase run the command: 
sudo apt install python3 

**Step 3: Install modules for Kano Wand**

In terminal:

> cd /usr/local/lib/python3.9/dist-packages

then

> git clone https://github.com/GammaGames/kano_wand.git

> sudo pip3 install bluepy moosegesture

Had to use sudo for these to get the proper permissions. Also had to use the following commands instead to install numpy, for whatever reason, couldn't get pip to work. Might have been another path issue, but this worked for me so I went with it:

> sudo apt-get install python3-numpy

**Step 4: Clone the Hogwarts Legacy Wand repository**

Find a place where you want to clone the respository to, I essentially did it in my "Downloads" folder. So to return to home, type and enter:

> cd

then 

> cd Downloads

> sudo apt install git

> git clone https://github.com/Thats-so-Mo/Hogwarts-Legacy-Wand.git

> git clone https://github.com/GammaGames/kano_wand.git


Second thing: Turn the Raspberry Pi Zero W into a USB HID Device

Now you have Hogwarts Legacy Wand downloaded but its not ready to be used as you need to convert the RPI Zero W into a USB HID device; which can be easily done by following this tutorial. This is so that it makes it possible for the wand gestures to emulate keyboard button presses. Follow it all the way to Step 4. If you want to ensure that it is functioning as USB HID device, complete step 4. Remember, you followed the tutorial to step 4, YOU MUST CONNECT THE USB CABLE IN THE DATA USB PORT TO THE USB PORT On the PC WITH HOGWARTS LEGACY RUNNING ON IT.

Once done, launch terminal;

cd Downloads\Hogwarts-Legacy-Wand

chmod +x Hogwarts_Legacy.py

sudo ./Hogwarts_Legacy.py

sudo is needed due to bluepy being a bit of #$@##@ (permission issues)... If its done all correctly, it should start showing "scanning" in terminal...

When casting a spell, hold down the button on the wand. Down below are wand gestures that can be currently found within Hogwarts Legacy Wand code.

Third Thing: Wand Gestures - Add/modifying/Removing Wand Gestures

In the "class GestureWand(Wand)" sectopm, under the self gestures part. This is where you put in the gestures/spells you want to be able to perform. Some have been pulled by GammaGames and put in such as lumos where as I put in the accio, reparo, revelio and etc by using existing information available on their wand movements looking around online, on certain wikis or even on the kano wand spell sheet however for ancient spell and ancient throw spell, basic spell, etc - i just made it up.

For example, ancient throw spell is just me tracing the letter Z in the air with the wand - Z being the letter to press for ancient spell in Hogwarts Legacy by default.

But if you want to insert accurate gestures and wand movements - use GammaGames gesture script, trace the spell with the wand and it displays the corresponding movement and then just copy and paste it into my script and give it a name. There are 8 different directions that the wand can detect; Up, Down, Left, Right, Up left, Up Right, Down Left, Down Right.. Flick the wand up - you get a U… you get the gist. Do a bunch of wand movements, it translates those movements in those 8 directions and then spits out the movements you did with the wand. Pretty simple - works great and surprisingly accurate. If you want to add your own spell, just copy the format of another spell or rewrite an existing one (e.g. reparo, Idk why i have so many) and then bobs your uncle.

Now in the "def main():" section

We get a bunch of "ifwand spell" commands.

The first you see are the default spells such as Protego (which is the letter 'Q'), revelio (letter 'R') and basic spell being the letter 'B'. With basic spell, I did set that up in Hogwarts Legacy to be the letter 'B'.

Using protego as an example,

When the script detects the protego spell casted by the wand, it will first print [protego spell detected] and then send the corresponding key press to the pc which in this case is the letter 'q' (write_report(NULL_CHAR2+chr(20)+NULL_CHAR5)).

Then it releases the “keyboard” (write_report(NULL_CHAR*8)) - without this line. It will pretty much spam the letter ''

"write_report(NULL_CHAR2+chr(20)+NULL_CHAR5)"

The "20" value is the decimal value of 'Q'. if your protego is actually the letter M, you use the Univerisal Serial bus hid usage table (https://www.usb.org/sites/default/files/documents/hut1_12v2.pdf), scroll down to Table 12 of the document to find its corresponding value and replace number 20 with the number 16 (From Table 12)

  • Thats it - no other changes are needed

Now, if you want to change a spell, lets say in row 1, spell number 1, all you need to do is change expellarimus to another spell such as wingardium_levisa and thats pretty much it….

Now I know this method, this code, isnt perfect. When the spells have been chosen, with each number and row associated for each spell. This makes it so that there are 4 different wand gestures, four spells that can trigger a button press.

For example with number 2,

There are four spells that can trigger number 2; incendio, disillusionment, flipendo and windgardium leviosa. If your in the wrong row such as the first row but you do the wand gesture for windgardium leviosa, it will trigger incendio. So its up to the player to remain vigilant. I have so far set myself up that the first row are the spells that I want to use during battle while the other rows could be used for different utilities such as conjuring.

UPDATE V2:

Reddit user (thistallasian) suggested this bit to improve spell casting:

"Great work! IIRC you can use F1-F4 to change your spell rows, which means you should be able to cast all 16 assigned spells without flipping rows using ",". For example, you could have "expelliarmus" write F1 (58) followed by 1 (30) while "lumos" writes F2 (59) followed by 1 (30)."

Essentially, assign F1-F4 to each row which then whenever we cast a spell, it sends the correct F* and then casts the correct spell. BEFORE:

            if wand.spell == "expelliarmus":
            
            print('expelliarmus spell detected')
            
            write_report(NULL_CHAR*2+chr(30)+NULL_CHAR*5) #press number 1
            
            write_report(NULL_CHAR*8)
            
            wand.spell = None

AFTER:

            if wand.spell == "expelliarmus":
        
            print('expelliarmus spell detected')
            
            write_report(NULL_CHAR*2+chr(58)+NULL_CHAR*5) #changes to correct row (F1)
            
            write_report(NULL_CHAR*8)                
            
            write_report(NULL_CHAR*2+chr(30)+NULL_CHAR*5) #press number 1
            
            write_report(NULL_CHAR*8)
            
            wand.spell = None

Thanks thistallasian - great idea

Hogwarts_Legacyv2.py

This is the updated code where 16 unique spells (no doubling in spells) can be casted at any given time. Basically you need to assign a F1-F4 for each spell row in Hogwarts Legacy now with this code. for example my first row would be F1. The way that it works is that when you cast a spell, it will automatically cast the correct corresponding spell.

For example, If I casted lumos, the raspberry pi will send out the F2 key press (as F2 is assigned to row 2) and then the number 1 will be sent to the game, initating the lumos spell.

then afterwards, I can then cast expelliarmus, the code will then switch the row to F1, send out the number 1 button press and then cast the expellarimus spell.

THIS IS UNTESTED! Please note. The spells used and their gestures may not be 100% accurate.

Thanks to thistallasian from Reddit for this suggestion.

About

Use the Kano Wand for Hogwarts Legacy (PC Only)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages