yego.me
💡 Stop wasting time. Read Youtube instead of watch. Download Chrome Extension

MMOs in the Instagram Era: Highrise (S18) - YC Gaming Tech Talks 2020


3m read
·Nov 3, 2024

Processing might take a few minutes. Refresh later.

Um, hi everybody! I'm Jimmy, I'm the co-founder and CTO of Pocket Worlds. We're High-Rise, and we built High-Rise, the app which is available on iOS and Android. I think to date, it has over 5 million downloads, and we're grossing over a million a month in revenue.

So today, I'm going to walk you guys through the process of designing and building an MMO game in this era of mobile apps and social networks. I'll talk about the architectural design decisions that we made that enable High-Rise to feel simultaneously like an app and also a game, and why that's really important. I'll also talk about our vision as Pocket Worlds and how we plan to leverage the High-Rise architecture to create more exciting social-first game experiences and worlds.

For those that are not familiar, High-Rise is a social-first design MMO. Player players come in, they design an avatar, they build an apartment, they go into this fully user-generated world to visit other people's spaces and take part in challenges. The unique part of High-Rise and the High-Rise experience, compared to the multitude of games that you see in the app store, is our design philosophy that we call social-first.

So with traditional game design, you often have a game designer that would come up with a game, a mini-game concept, and then would build out a meta-game loop and finally sprinkle in some social features, like lands, inboxes, marketplace, as almost an afterthought. Under the social-first philosophy, what we do is we start with the messenger, a news feed for a community, guilds, profiles, an economy, and a vibrant world, and then we add in the game.

In the case of High-Rise, that game is a straightforward fashion contest where you design outfits and compete with other players. The core part of why social-first works is that it solves the critical piece that's missing in most all mobile games today, which is the issue of long-term attention. A player joins High-Rise for the design game, but they really ultimately stay for the friends they meet in our world.

But as you can see, kind of from the screenshots on the left, our heavy focus on social features really requires a UI that feels like an app, very much like Snapchat or Instagram. Otherwise, users will come in, play the game, make their friends, and then really move to those other platforms once they're done and kind of gotten everything they can out of the game, and that's precisely what we saw in the early days of High-Rise.

So to achieve that user experience, we really realized that we must leverage the UI capabilities native to iOS and Android and could not rely on anything that game engines like Unity can offer. There's just really no way that Unity could compete with Apple's 40 years of experience perfecting fonts and UI animations.

So the architecture that we came up with actually mirrors our product's position of being 50% app and 50% game. It is 50% Swift and Kotlin on the Android side, and 50% C++. The Swift component handles all UI to create the silky smooth native feel, and the C++ component handles the game engine, the world, the avatars, business logic, and is shared as a sub-module between iOS and Android.

The components are seamlessly integrated via a system of bridges that are separated by feature, which creates a nice little microservices architecture that we can swap components in and out of. The bridging between the components is achieved using Objective C++ on the iOS side and JNA JNI on Android. The secondary objective here is, of course, to offload as much of the heavy lifting as possible into the core to help with cross-platform development, which we were able to achieve.

So I think what's more interesting is that this architecture really enables us to create different games and products that offer different experiences by swapping out the mini and the meta-game of High-Rise with something else. So maybe, I'm thinking like a hero collector where you're walking around in a virtual world collecting monsters to do battle with, with the exact same avatar, world, messenger, guild system as High-Rise, or an adventure fishing game. But yo...

More Articles

View All
El Niño 101 | National Geographic
A natural force of nature unlike any other, El Niño is capable of unleashing a fury of climate changes and natural disasters that span from Alaska all the way to South America and beyond. What causes El Niño, and how are we affected by it? El Niño is not…
Sal's back to school 2021 message
Hi everyone, Sal Khan here from Khan Academy. We’re entering into yet another back to school, but this is a back to school that’s very unusual compared to all others. We hope that we’re finally going to get to some level of normalcy as we see the light a…
The Flow State: How to Supercharge Your Life
In 1993, Michael Jordan led the Chicago Bulls to victory over the Phoenix Suns in what is widely known as his greatest NBA Finals ever. He averaged 41 points per game, the highest ever in NBA Finals history, cementing his place as one of the greatest, if …
5 Games That Will Get You Laid: V-LIST #2
Hey V saucers! My name is Danielle, and I’m back today to tell you some games that your girl will play with you, and she might actually like it. Now, one of my most recommended games to get your girlfriend to play with you is Halo 3. Halo 3 is a really, r…
Are There Lost Alien Civilizations in Our Past?
When we think about alien civilizations, we tend to look into the vastness of space, to far away planets. But there is another incredibly vast dimension that we might be giving too little thought to: time. Could it be that, over the last hundreds of milli…
Worked example: Finding the percent ionization of a weak acid | AP Chemistry | Khan Academy
Let’s say we have a 0.20 molar aqueous solution of acetic acid, and our goal is to calculate the pH and the percent ionization. The Ka value for acetic acid is equal to 1.8 times 10 to the negative fifth at 25 degrees Celsius. First, we need to write out…