BumperMouse
data:image/s3,"s3://crabby-images/990eb/990eb14a103b2ce78a555e949876029598e9b1ad" alt=""
Get a friend and test it out: https://bumpermouse.glitch.me/
Getting Started
The p5 Web Editor
I started building and exploring the primary interaction in the p5 web editor. While I knew that I wouldn't be able to build the functionality for multiple cursors there, it provided an easy way for me to explore a proof of concept and test a few questions that I had at the onset of the work. The first question to solve was how/if I could manipulate the mouse cursor. I landed on hiding the mouse cursor when a user is over the p5 canvas, and "re-drawing" a mouse cursor that I could control. Keeping the look and feel of a typical cursor, but introducing different colors felt like a good way to create a sense of play while embracing the medium of a web app.
data:image/s3,"s3://crabby-images/eba63/eba6327b9e43d8b5915506003024cb972d50b3f6" alt=""
The initial explorations in the p5 web editor also allowed me to easily write the a class for the mouse cursors, and test out a "bounce" interaction. Using vector math, I was able to first get the faux mouse cursor to slowly catch up to my cursor. After this I progressed to figuring out how to get the cursor to "bounce" off the edge of the canvas.
data:image/s3,"s3://crabby-images/d9605/d960508eaab5ed6f216795b6b933ce48764a2720" alt=""
data:image/s3,"s3://crabby-images/c006d/c006da10c11905a314dc928910779ff5a0470e2d" alt=""
Stage 2
Multiple Mice
With this proof of concept in hand, I needed to move into a platform that would allow me to test code with multiple users. I moved the code into Visual Studio Code to build the server and initialize web sockets. It also got me to quickly build a very lite html site to house the work. I decided to keep a relatively small canvas and keep it consistent for all users. Given the multiple positionings that would have to be transferred, I thought this constraint would help me avoid future problems.
After building all of this out, I quickly realized a major obstacle for user testing. When opening the page in multiple windows, I wouldn't be able to see two mouse cursors moving from the same computer. In order to continue, I needed to immediately move the project to glitch (or a similar platform) so I could even test enough to build.
After moving into glitch, I needed to start to think through how best to send information between users and what to send. After attempting to send my mouse objects through sockets, I simplified to simply send through the x and y positions. With that I was able to wire things up enough to show the multiple mouse objects and reveal the distance between the users.
data:image/s3,"s3://crabby-images/aa575/aa57515eb390b8003f51008b12336464f4d5ece7" alt=""
Things were more or less working well at this stage, except if I attempted to add in a third user, we had issues. Specifically, things began to aggressively lag. I needed to re-examine what information I was sending and to whom. I needed to rethink how web sockets were actually working. It turns out I was over-shipping. With every user's, every mouse movement, I was attempting to send information about every single mouse to and from every client. Rather than sending all of the information every single time, I only needed each client to send their information which could then be broadcast to all of the other clients. I needed to focus on sending information one at a time, and allowing the sockets to handle the multiple streams of information that were coming through.
data:image/s3,"s3://crabby-images/32073/320730ee8021551e739b1de7d79d9e717bd54c8e" alt=""
data:image/s3,"s3://crabby-images/0fbe0/0fbe08a67b3490b4e44942bf01a0592737c12a75" alt=""
data:image/s3,"s3://crabby-images/d1725/d1725d9ea2125edffb475a8921ae8f29f324c1b2" alt=""
Stage 3
Bounce Interaction
This stack overflow breakdown was exceedingly helpful to me as I worked through the vector math. With a smoothed out solution to sending information via sockets, I was able to move on to the problem of the bounce interaction. I fluctuated between having the mouse collision check run for every mouse that wasn't mine, and check it against mine OR if I should have an array of the other mice and then check my mouse against every other mouse. After trying to make the first one work, because I suspected it would be lighter weight, I broke down and re-wrote things so that my mouse was responsible for everything, other than displaying the other mouse objects.
With the puzzle pieces in place, I started to work out the vector math to determine the "bounce" of a collision. Initially, I did the math so that your mouse would hit another and then move a specific vector away from the bounce. But this led to a bounce that was very fast and difficult to control, because the mouse was rushing to get away from the initial bounce. I ended up re-working this section to actually first determine a vector point away from the bounce interaction, and then pull the mouse cursor there as a target. It was a simple shift but it smoothed out the bounce interaction in a nicely nuanced way.
data:image/s3,"s3://crabby-images/a81f3/a81f39322b2384e674a8ddf2a6fa8e65f24ff7b3" alt=""
data:image/s3,"s3://crabby-images/3da42/3da42e71552d25a424e3d6a2c6c4f4e3484b64e6" alt=""
While working through these problems, I ended up adding in a number of features for the sole purpose of debugging. Especially when working through the vector math and positioning, I found it helpful to simple render the labels of where the vectors were in space. This helped me better visualize what I was doing when I was manipulating points mathematically. At times I was labeling every mouse cursor with their client ID, labeling vectors, or having different "traffic lights" at the top to clue me into what was happening within my code.
data:image/s3,"s3://crabby-images/55c0a/55c0a0e1df5f3dc607aa2fa61477c5906964020c" alt=""
data:image/s3,"s3://crabby-images/ae1f6/ae1f60c26760373ae07f1bce04e5b16ac1af450c" alt=""
data:image/s3,"s3://crabby-images/d6169/d616915c4559c2dbaa678e572717ed43e9c3f381" alt=""
Debugging Hall of Fame
data:image/s3,"s3://crabby-images/37114/37114e8db254f4a17ac79223fb33c12a46e4d103" alt=""
data:image/s3,"s3://crabby-images/88a0b/88a0b1e212b5dfb299a242ef54a1f4d653d5a106" alt=""
data:image/s3,"s3://crabby-images/d249d/d249d001d5e51478b74bb256c3b230604aeb8f00" alt=""
data:image/s3,"s3://crabby-images/ea8dc/ea8dcba27e920d0f8a54b3f1552a7fcbd26a29a1" alt=""
data:image/s3,"s3://crabby-images/da760/da760a048dfa8668fa365b5f88988b5ccb754139" alt=""