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
Philosophies on Failure & Learning
Life looks like this to me: um, you know, you start off and you head in a direction, and you evolve. And then you have your setbacks and the pains and so on. Ideally, you learn and you readapt, and you go on, and you have another one of those. It’s that p…
Marcus Aurelius and the Guiding Principles of Stoicism
In the year 165 CE, a black wave of death rose from the East and quickly spurred across the globe faster than anyone could have ever imagined. They called it the Antonine Plague after the reigning Roman Emperor at the time, Caesar Marcus Aurelius Antoninu…
Unbreakable Bonds | No Man Left Behind
I think if you want to know the story of Blackhawk Down, then go look it up on the internet. Go watch the movie; read Mark Ball’s book. You’ll get a great historic version of what happened, and you’ll get a bit of a human perspective. I’m sure Ridley Scot…
Why This Museum Stores Thousands of Dead Animals in Its Freezer | National Geographic
Humans have altered the environment more so than any other species that has lived on the planet. We see animals in our environment that are having to adapt to the world that we have essentially fabricated for them, and that includes them dying as a result…
Calculating a confidence interval for the difference of proportions | AP Statistics | Khan Academy
Duncan is investigating if residents of a city support the construction of a new high school. He’s curious about the difference of opinion between residents in the north and south parts of the city. He obtained separate random samples of voters from each …
Analyzing unbounded limits: mixed function | Limits and continuity | AP Calculus AB | Khan Academy
So, we’re told that ( f(x) ) is equal to ( \frac{x}{1 - \cos(e^x) - 2} ), and they ask us to select the correct description of the one-sided limits of ( f ) at ( x = 2 ). We see that right at ( x = 2 ), if we try to evaluate ( f(2) ), we get ( \frac{2}{1…