Categories
Dev to Dev

How to build an AR app like Pokémon Go in three simple steps

If you haven’t been living under a rock, you’ve heard about the Pokémon Go app. This game has already picked up more users than Twitter and helped push Nintendo’s market capitalization over $69 billion in 2020 (and counting!). Pokémon Go app is also a great example of a location-based (LBS) game and geo-based augmented reality.

Much of the success is due to the phenomenal fan base Pokémon already had in place. Another success component is clever use of smartphone technology, including very easy-to-use AR. And here’s the great news for developers: all the tools to build your own location-based AR game are already out there. We’re quickly going to show you how to use them in three simple steps.

OK, it’s a little more complicated than that, but once we break it down to fundamentals, you’ll see how simple it really is to build your own kind of Pokémon Go app.

Ready? Keep on reading!


Step 1: Set up a basic Geo-based infrastructure

Setting up the server infrastructure for such a game requires some work. You need to manage user accounts and arrange a smart distribution of Pokémon characters or objects of your choice in addition to some contextually aware components in your system.

For simplicity: let’s assume that you already created the server backend required to fetch the closest 5 creatures for any given user position so that once you know where the user is you get a list of them in a JSON Format (making it easier to parse in your JavaScript code).

Placing objects (such as Pokémons) around users using their GPS position was actually the very first feature supported by the Wikitude SDK since 2012.


Step 2: Build a geo-AR app

The Wikitude SDK JavaScript API also offers features to fetch the user’s location, and place videos, 2D and 3D content in geo-spaces. You can query content from a remote origin to create a personalized Geo-AR scene on the fly.

The Wikitude JavaScript API offers so-called AR.GeoObjects, which allows you to place virtual objects in the real world. A callback function informs you about user movements, firing latitude, longitude, and altitude information. In the following sample, the user’s first location is stored for further use, using Wikitude’s JS SDK.

Note that this code must run inside a Wikitude AR-View, the central component of the Wikitude JavaScript SDK.

AR.context.onLocationChanged = function(lat, lon, alt, accuracy){
// store user's location so you have access to it at any time
World.userLocation = {"latitude": lat, "longitude" : lon, "altitude" : alt };
};

The following function uses coordinates to create an AR.GeoObject out of a 3D Model (in Wikitude’s wt3 file format) and an AR.GeoLocation.

createModelAtLocation: function (location) {

World.modelGeoLocation = new AR.GeoLocation(	location.latitude, 
location.longitude + 0.0005, 
AR.CONST.UNKNOWN_ALTITUDE);	
// load model from relative path or url
World.model = new AR.Model(World.PATH_MODEL_WT3, {
// fired when 3D model loaded successfully
onLoaded: function() {

// define model as geoObject
	World.GeoObject = new AR.GeoObject(World.modelGeoLocation, {
		drawables: {
			cam: [World.model]
		},
		onEnterFieldOfVision: function() {
			console.log('model visible');
			World.modelVisible = true;
},
onExitFieldOfVision: function() {
			console.log('model no longer visible');
World.modelVisible = false;
},
		onClick: function() {
			console.log('model clicked');
}}
);
},
onError: function(err) {
console.error(‘unexpected error occurred ’ + err);
}
});
}

Step 3: Make the rules of your game

Now that you can place virtual 3D models in the real world, you can get as creative as you can be and define the rules of your augmented reality game.
Here are some examples of what’s possible:

    • Similar to the Pokémon Go app, you may require the user to be a maximum of 10 meters (30 ft.) away from a 3D model experience, otherwise the player may not collect or see it. On top of that, you could also use altitude values to make sure a user has to get to the top of a building, or other unique locations.
    • Mix up the content! In addition to 3D models, you could also use videos, text, icons, or buttons and place them in any geo-location you like.
    • In addition to GEO AR, you could also use 2D image recognition and tracking: Use signs, billboards, print, walls, or any other 2D surfaces as “stages” for interesting and cool AR augmentations that are “glued” onto these surfaces as seen in this video.
    • If you want to take your game to the next level, use the environment around your user to extend the play with markerless AR or even include physical toys with object tracking to create immersive hybrid play experiences.

    Get an app template!

    Need an app template to get you started? No problem, just download the Wikitude SDK package, which includes an application called “SDK Examples”. One of the many AR templates you will find in there is called “3D Model At Geo Location”. Simply use this as a starting point for your code.

    You can also download Wikitude’s sample app (included in the SDK download package) for examples of how to build your own geo-AR experiences. Also, have a look at this helpful video tutorial made by a developer from our community:

    Additionally, check out this integration tutorial by LBAR – a third-party plugin, built on top of Wikitude’s comprehensive Unity plugin, offering location-based AR for Unity:

    That’s it! We hope you will build great geo-based AR apps with our SDK.

    Wikitude provides a wide selection of development frameworks. Developers can choose between using Native API, JavaScript API or any of the supported extensions and plugins available.
    Next to JavaScript Android and iOS, among the extensions based on Wikitude’s JavaScript API are Cordova (PhoneGap), Xamarin, and Flutter. These extensions include the same features available in the JS API, such as location-based AR, image recognition, object tracking and instant tracking.

    In case you have any questions, don’t hesitate to contact us via the Wikitude forum, we have a broad network of developers who can help you in creating the next big AR app!





Interested in creating an AR project of your own?
Talk to one of our specialists and learn how to get started.

Contact The Wikitude Team

Categories
SDK releases

Wikitude SDK 8.6: HoloLens + Flutter Plugin + Geo AR for Unity

After another productive product improvement cycle, the Wikitude team is excited to present SDK version 8.6. The update includes our powerful – now product ready – HoloLens AR package, introduces support for Flutter, adds Geo-AR for Unity users, and offers further performance enhancements.

Wikitude SDK 8.6 at a glance:

  • Wikitude SDK for Hololens – production version
  • Flutter Plugin – release candidate
  • Geo AR for Unity Plugin (by PendAR)
  • Performance and stability enhancements

Wikitude SDK for HoloLens – Production Version

The Wikitude augmented reality SDK for Microsoft HoloLens 1 is Unity based, comes with a Holographic UI sample app, and is now available in production version. 

A little over a month ago, we launched our HoloLens AR SDK release candidate. The package allowed our customers and partners to test Wikitude Object + Image + Cloud and more HoloLens AR-tracking technology features within their projects.

The response has been very positive. And we have also received valuable feedback which enabled us to improve the platform even further, resulting in a powerful production-ready HoloLens AR SDK. 

With Wikitude SDK 8.6, companies can now purchase and download our augmented reality package for Microsoft HoloLens 1 to create high-performing AR solutions.

New Image Recognition samples for Wikitude AR SDK for HoloLens

Make sure to check out the new Image Target samples to review the performance of the Wikitude SDK for HoloLens.

Additionally, you may access our Wikitude HoloLens Documentation section for further details, instructions, and information.

Augmented Reality for Flutter – Release Candidate Plugin

Wikitude SDK 8.6 is the first AR platform to provide official support for Flutter.

Flutter is an open-source mobile application UI development framework toolkit created by Google. It is used to develop natively-compiled applications for iOS and Android from a single codebase.

Wikitude developers can now work with Wikitude SDK 8.6 to add augmented reality technology to their projects created in Flutter. The Flutter Plugin is based on JavaScript API and comes with the full package: Wikitude AR library/framework, sample apps, and documentation.

Flutter AR Plugin: Feedback Welcomed

As this is a release candidate, we are eager to receive as much developer feedback as possible. When trying the flutter AR plugin, feel free to send us an email (info@wikitude.com) to share what you liked about the development experience and, most importantly, what you think could be improved. Every email received will be highly appreciated and taken into consideration in the improvement process.

Please access the Flutter package manager to install the plugin.

Geo AR for Unity Plugin

Location-based augmented reality is a big hit among the augmented reality community. Starting with Wikitude SDK 8.6, and thanks to PendAR – augmented reality partner of Wikitude, developers can now use LBAR to create Geo-AR experiences in no time in Unity3D. 

LBAR offers a very simple workflow for location-based applications. It can be integrated with other apps in Unity3D, and there will be no need to put effort into geo calculations. LBAR also offers a simple and easy-to-use radar so users can have a better understanding of their surroundings.

Access the Wikitude download page to select the LBAR Geo-AR SDK package.

AR SDK Performance and Stability Enhancements

With every new Wikitude SDK release, our quality assurance team takes the opportunity to review and optimize the platform to ensure all AR features, classic and new, are performing as they should be, enhancing stability whenever possible.

Wikitude SDK 8.6 includes a series of fixes and stability improvements. Please review the release notes for your platform for an in-depth report.

Download Wikitude SDK 8.6

Active Wikitude SDK subscribers are entitled to all SDK version updates released throughout their term. Follow the links below to update your SDK:

New to Wikitude? Download a free Wikitude SDK 8.6 trial version for testing purposes and contact our team to discuss upgrade possibilities.

To explore all SDK options, including smart glasses, plugins, and other dev tools, please access our download page:

Interested in creating an AR project of your own? Access our store to choose your package or contact our team to discuss your specific AR requirements in detail.