Posted by Kim on April 27, 2018, 10:51am
Note from Kim: The following is an article written by my father, the force behind the Doubutt game's code. He wanted to share the story of how it came to be with all of you. data:image/s3,"s3://crabby-images/87c70/87c704ede43f88342ba222a3649051deb7fb8894" alt=":) :)"
data:image/s3,"s3://crabby-images/87c70/87c704ede43f88342ba222a3649051deb7fb8894" alt=":) :)"
data:image/s3,"s3://crabby-images/3dcca/3dcca365b2b20b1f3441b3d73f57afe7f75a166c" alt="bouncyballs.png"
I thought you might like to hear a little about the development of the Doubutt game. Some of it is history, and other parts are technical. Just skip the technical parts if you're not interested.
data:image/s3,"s3://crabby-images/017c2/017c2da3ff4b4e8bfeff8023f27676f678b1e48b" alt=""
data:image/s3,"s3://crabby-images/f98ad/f98ad563487c025557ce095e6ed919c7eba4a885" alt=""
Doubutt was written in Java so it would easily run on multiple platforms including Windows and Mac OS. My dream from the beginning was to be able to run the game in the browser as well as the desktop. To accomplish this I planned to write a Java to JavaScript converter. Despite JavaScript having the word Java in the name, JavaScript and Java are two very different languages. Java is a compiled statically typed language designed to run on many operating systems. JavaScript is a dynamically typed interpreted language designed to give web pages behavior. So I couldn't just drop the Java code into the browser and expect it to work. Running in the browser would have to wait. First we had to get it running on the desktop.
data:image/s3,"s3://crabby-images/7253e/7253e865feecb1d22f2e63fe49fdc1c5e3b1abce" alt=""
I went on a crash course of converting the game from Java to Scala to get it ready for Epic week 2017 at the end of April. Last year when you played Doubutt you were running the Scala version, even though it was still desktop only.
Converting to Scala wasn't the only step needed to get Doubutt running in the browser. There were a number of services from Java I depended on that would have to be rewritten to get them to use the corresponding service in the browser. Here's a list of those services: sound, dialog boxes, graphics, file IO, XML and JSON parsing, dynamic code invocation, timers and logging. I didn't want to lose the ability to run Doubutt on the desktop as I added support for the browser. I designed an abstraction layer to provide the game with the needed services. I created two implementations for these services, one for the desktop and one for the browser. It took until March of 2018 to get Doubutt to start working in the browser. This was so late that we thought we would have to wait until Epic Week 2019 to see the dream of Doubutt running in the browser be realized. And it still runs on the desktop. It's often easier to debug a new feature of the game on the desktop, even though the plan is to deploy it on the browser.
data:image/s3,"s3://crabby-images/34c31/34c3155c34bc43bd10701404e8c2162b8330b80e" alt=""
In 2018 the browser is very powerful. The HTML canvas element provides a very capable 2D graphics system. The sound API is as powerful as the desktop sound API. Unfortunately Apple has not adopted the latest W3C standard for sound. Their API is close, but not close enough to get the sound working in Safari in time for this year.
As this is the first year that Doubutt runs in the browser, it is in some ways still experimental. There are some strange display issues we will continue to work out, like black lines that sometimes appear between tiles when Doubutt walks. But there are also major advantages. For example, this is the first time that the Doubutt game may run on tablets, mobile phones, other touch screen devices, or on computers that for whatever reason could not install Java. I say "may" run because some of these devices will not be powerful enough to run the game smoothly, especially when the physics engine is working hard to bounce many balls. Still, this expands the number of people that the game is potentially available to, and that's a good thing.
Post tags: Epic Week 2018
Comments
Thanks for the insights, onion!
Woo! Lovely read and hi to Kim's dad!
But for reals though--I suuuper appreciate this insight into the backend!
Thanks for Kim, onion
data:image/s3,"s3://crabby-images/7b4cc/7b4cca868c00b90dc5992ee6b767cea6d2b1a54c" alt=";) ;)"
Fantastic piece of coding there, and a very well achieved game given the constraints and limited time
Congratulations on your great achievement
Congratulations on your great achievement
You're welcome, CelestinaGrey.
Thank you for all your hard work and an awesome game, Kim's dad!!
data:image/s3,"s3://crabby-images/2f0ba/2f0ba038fe72640a5b30db4dd2e1df3d5516128c" alt=":D :D"
rat
April 28, 2018
2:58am