Showing posts with label Games. Show all posts
Showing posts with label Games. Show all posts

Sunday, 3 March 2013

Easy Property Syncing over Network in Unity

A while back I was experimenting with network code in Unity. To make syncing variables easier I made something I called a 'NetworkMonoBehaviour'. This makes it easy to do exactly what the titles says, easy property syncing over a network in Unity. So here's how it works:

Properties

So we start with a field and, since we like clean code, we encapsulate it with a property.

Networking

Though now, if we change it, it will only be changed locally. This isn't what we want in a network game. So I wrote some code that makes it possible to do this:
This will change the _speed field locally and tell all connected players to do the same. It will only do it if the speed actually changed to minimize network usage. This is made possible by using my NetworkMonoBehaviour. Instead of deriving from MonoBehaviour you derive from NetworkMonoBehaviour with the classes you want to sync. They are still MonoHebaviours, but now indirectly. This makes it possible to used the a few very useful methods in this class. NetworkChangePropertyIfChangedNetworkChangePropertyAndCallMethodIfChanged these are the most used, and their names should explain what they do.
If you just want to use it, and don't want to know how it works, you can stop reading here. Just download the NetworkMonoBehaviour here.

NetworkMonoBehaviour

This is the entire NetworkMonoBehaviour class:

All of these methods will work with int, float, string, Vector3 and Quaternion. Otherwise an exception will be thrown.
The class is actually pretty simple. After checking if the value actually changed, I check what type the variable is (int, float, string, ...) Then I cann the correct RPC. These RPC's are methods that get called on all connected peers, and I made one for every type, which changes a field based on it's name.


Voila, now you can easily sync your properties over a network.
Thanks for reading!

Tuesday, 5 February 2013

First-Person Adventure Kit (Unity)

Lately I've been making a lot of unfinished project. Most only go as far as making a basis for the game, so I've decided to put some of this online so other people (you!) can use it and hopefully learn something of it. You can use those code as-is, or alter it in any way you want. You can also use it in any game you want, even ones you sell.

What does it do?

So, first things first. What does this project do?
It's a very simple set-up to make a first-person adventure game. It contains a player script, which can walk and look around. On top of that it can interact with object in the world, and that's where it gets interesting.
But first, here's a link where you can try it out. Walk around with awsd (or zqsd for azerty) interact with leftmouse button (the wheel can be turned backward with the right button.)

How it works

Player

The player should be pretty straight-forward. It's a simple script which does the walking and the looking. It has basic first-person controls.

Variables

You can set it's walk-speed (m/s), jump strength (3.5 will make you jump just over one meter) and it's look distance (in meters.)

Pushing

By default a Character Controller can't push Rigidbodies in the world, so I added a few lines of code so it can push, the 'Pushing Power' variable sets how hard the player can push. (Look in OnControllerColliderHit for how this works.)

Objects

Now the interesting part. How does the interacting work. I've tried to make it so it's very easy to add new interactions without having to modify any code, only add a new script.

So, let's take the little green cube as en example.

Interactable Object

First of all, each and every object you want to interact with needs to have an "Interactable Object" script attached to it. This is used to gather all the interactions and tells the player-script that this object can be interacted with. It also cashes the interactions so only the first time you look at the object they need to be collected. This is also the script the player communicates with.

Interactions

If your object is an Interactable Object you need to add interactions. Interactions are custom scripts (I already made a few as an example) which define what your object does when the player interacts with the object. Instead of deriving directly from Monobehaviour they derive from Interaction (which is a monohebaviour.)
...

If you do this, you can override a bunch of methods and by that define what will happen when you interact with the object. You can add multiple interactions to the object and they will all work simultaneously. If you want an interaction to only work when something else has happened first, you can do this with custom code you write yourself.

Looking at the Interaction class you can see there's a lot that can be done with this:
So if you derive from this class and override one or more of these methods it'll work like magic! As you can see, by default the methods are empty, so if you don't override them they'll just do nothing.

Rotator

Rotator is a very, very simple class I wrote to make the wheel rotate when you interact with it. The wheel is the round red/green/blue thing on the blue box.
So, while I'm holding the use-button and looking at the object the HoldingUse method will be called. This will make the object rotate. While I'm holding the inspect button it'll rotate the other way. Very simple, almost no code and it just works!

DebugInteraction

Lastly I wrote a little DebugInteraction. This script shows when which method is called. All methods that are called once (StartXXX, EndXXX Use, LongUse, Inspect and LongInspect) are written to the console. Those that are called every frame keep how long they are being called and it's shown in the top-left of the screen (as you can see in the web-player.)

Download

Now you know the basics go check out more of the code and play around with it a little! You can download the project right here.
Note: I have custom input settings, so if you use it in your own project you might need to change these a little.


If you want some of the code explained more just comment here or email me, and I'll be happy to help!

Have fun coding!

Thursday, 22 November 2012

Choosing an iOS Engine Update: Sparrow

Hi,


A while back I wrote about choosing a game engine for iOS. And now I want to add one to that list. The one I want to add is Sparrow:

Sparrow iOS

This is a great 2D game engine. It rivals Cocos2D, though might be even better. It's not as big as Cocos, both in features and community, but it's more concentrated. One of the problems I had with Cocos2D is that there simply is too much, which can make it annoying to use. Sparrow doesn't have that problem, it's much cleaner.
It does however miss some features, the biggest being a build-in physics engine. Though you can just use Box2D (which is what Cocos2D uses too) and make them play together yourself, which isn't too hard.


As a bonus I also want to note that Unity just got an update, now it's at version 4! The best thing is that it now has social API's, so you can easily promote your game by posting stuff to facebook or twitter. There are also a bunch of other cool new features, but that's not what this post is about.

So yea, have fun making games!

Saturday, 8 September 2012

Web-Apps without Javascript

Hi,


Recently I've gotten very excited about web-apps, little programs or games that live in your browser. The great thing about them is that they work on any device that has a web-browser. That means they work on your home computer -whether you're using Windows, Mac or Linux- but also on your iPad or any other tablet. This is really awesome. Another great thing is that you can circumvent Apple this way, you don't have to put your app on the AppStore, you don't have to pay the 100$ developers fee and you don't have to wait weeks before it gets reviewed!
The downside, however, is that you'll have to use Javascript, which, in my opinion, sucks. Luckily it's not true! In my search for a better way of creating web-apps I found two very promising alternatives to Javascript, and they are both great.

Google Dart

Google Dart is great. It's an entirely new programming language made to replace Javascript. It's a proper programming language, looking a lot like the C-family. It's properly object-oriented and supports interfaces, generics and (optional) typing. The beautiful thing about it is that it compiles to Javascript, so even though Dart isn't supported by most browsers yet -only by a nightly build of Chrome-, the apps you make can still be run in them. And since Google is backing this project, with a little luck you'll see support for Dart soon.
Now, Dart isn't perfect yet. Since it's very very new, there aren't many tutorials yet, so learning it isn't as easy as other languages might be. Neither are there many libraries yet, so you'll have to make everything yourself. Though this might be a positive point, if you like making libraries and tutorials, this is a whole new world that needs your help!

Haxe

The second alternative I found is Haxe. Haxe might be even more awesome than Dart. Haxe, just like Dart, is a whole new programming language. Though instead of being specifically for web-apps, it can do a whole lot of stuff. It too compiles to Javascript, but also to Flash and natively to Windows, Mac, Linux, iOS, Android and more!
Haxe's syntax looks like Java or Actionscript. Just like Dart, it's object-oriented, strictly typed, supports generics, and more. Anything a modern programming language needs.
Unlike Dart, Haxe is already widely used. So it has a bunch of tutorials and libraries for you to use. And even though it doesn't have a big company like Google behind it, it has a very active development team and community. On top of that it also has a very good standard library. Also, if Dart ever becomes the new standard, someone will probably just make a compiler from Haxe to Dart.

Update 12/09/'12

I've been working a bit more with both Dart and Haxe and wanted to add that Haxe truly is a more mature language. It's just been in development for much longer, and has some features Dart is missing. It's just a matter of time before Dart adds these features, though right now Haxe seems to be the better choice.


So, now you know your options when you want to make web-apps but Javascript is killing your buzz. Both languages are great, and both are worth a try.

Wednesday, 13 June 2012

Choosing an iOS game engine

Hi,

I'm planning on making an iPad game, so I was looking around for an engine to use. I looked through a whole lot of engines, tried a bunch and selected three. If you are looking to do some development yourself, read this and you'll know what engine is perfect for you.
All engines in this post have the ability to compile for iOS, though they all can also publish to other platforms. I'm here to select one for an iPad game, but you might find the perfect one for an other platform too.


Cocos2D for iPhone

As the name suggest this one is for 2D games. It's really powerful and uses Objective-C as a programming language so it's the only truly native engine. Objective-C isn't easy though, so this engine is probably for people who already know some programming. It can make apps for both iPhone and iPad (and Mac too if you're interested in that.)

Cocos2D is for (experienced) programmers who want to make iPhone or iPad apps.


PhoneGap

This is another 2D engine. The big difference though, is that it doesn't make native apps. It uses HTML5 and Javascript to make the app. Thanks to this you'll be able to make iPhone and iPad apps, but also play your game in the browser, on android and pretty much anything else. Javascript is really easy so if you just want to make awesome games without having to learn a complex programming language, this is for you.

PhoneGap is for anyone who wants to make games, with or without programming knowledge. It's absolutely perfect for people with web development knowledge, since you'll be able to use the language you already know.


Unity 3D

Unity is awesome, it's definitely the best free 3D engine out there. You can program in c#, java and boo, all are easy so you can select the one you already know or just select the one that looks coolest. Unity is free to use for desktop and browser apps, though will cost you a bit when you want to publish to iOS. You can always make and try out your game on your pc and then later buy the iOS license. I have worked a lot in Unity and it's just really fun to make game in it.

Unity is for anyone who wants to make 3D games for any platform.



I hope this post saved you the time looking for an engine and that you now know which one you'll be using.

Update: Another great option might be Haxe. I wrote a new post about this and Dart, might also be a good option if you're making iOS games: http://anoddcupoftea.blogspot.be/2012/09/web-apps-without-javascript.html

Update: I added one to the list, Sparrow. http://anoddcupoftea.blogspot.be/2012/11/choosing-ios-engine-update-sparrow.html

Have fun making games!