Pages

Friday, December 7, 2012

Last post

I'll create personal blog in the google account which i'm using these days and i'll connect it to g+
It's much time that i'm not using this account anymore. Name of the blog also do not reflect its purpose much.

Writing again

It's a while that i wasn't writing anything. I did not have the time or maybe i did not feel the need. I do hardly at the moment and from weeks ago.
I'm listening to metallica's master of popits and its stil awesome. I'm out from MindHammerGames. I could not work with the other members anymore so i tried fixing and when i could not and saw the problems deeper than that, i choosed to continue my journey without MHG and it's projects and plans.
It caused me to have lots of additional work to have but having work to do is a great thing for many reasons. One of them is that the mind  will freze and you have much to do so you don't think much. Sometimes it's the most valuable thing in the world. Thinking is a great thing and great tool but sometimes it becomes problematic, specially when your sub consious is trying to complicate things and make them look bad.
ok so what i'm doing. Creating a new team and a new name and website for the team that i should lead and move forward. People's amount of revenue and the final quality of some products will be under my responsibility so it's not a joke. I should do it as good as i can. Many friends are helpful to me these days. Many family members as well. I don't feel good at all when someone is doing something for me because i think it's my own duty to do all of that or hire someone for it. I feel very ok about doing things for others but not the other way. I can not understand fully, what is the reason.
Things are going forward, my emotions are being touched once in a while and generally i became sensetive these days. For now don't feel much power inside and this is one of the times that i think that i'm not capable of doing much. I think people generally in one of the two states (i'm talking on those people who sometimes do some stuff good). Either you think that you are capable and will do some stuff or feel that u are a piece of garbage. It the second most of the times for me when it comes to anything other than work.

Friday, February 3, 2012

New experiences can be ...

For the first year we had a gamejam in Tehran. We in co operation with our friends at proshot hosted the event and only one other team joined us due to multiple reasons. Some of them are cultural and due to the fact that we did not announce it on many places and the fact that game development is new in our country and to some extent because it doesn't happen in weekends in Iran.
We thought that we can create a demo which could amaze people with a clean code base and great technical abilities and hopefully a creative idea. Different things caused us to fail in our first gamejam. I just want to describe the experience in the hope of being helpful.
We previously did this. We've made demos in less than 10 hours to show them to people or to show our coding speed and technical abilities multiple times. We were good friends with the highly stressful nature of game development in short time slices but we've made them playful and joyful for ourselves. But GGJ was not successful. Why? The week before GGJ was a hard week for me and I was suffering from sleeping less than (well much less than) enough all days in the past week so I was tired in the second day. We treated the theme much serious, much more than needed and spent the whole first day in talking. Also we've never worked with the whole team in a project like this.
All of those demos which were built in short time spans were built either single handedly by Sina or me or in cooperation between us. Due to eight years of working together and being long time friends it's much easier to have a flat structure and creating a hierarchy for two developers is just stupid. This time the flat structure was not the answer at all. We did not choose a leader and worse did not choose a game designer. Getting into something that all four of us agree on it wasn't that easy and at the end the idea was complex enough that we could not manage to create it so uLink saved us and we've just turned our game into a multiplayer shooter with a little philosophy behind it.
The game is called personal trap and is about selfishness or other self related concepts. Every warrior sees himself/herself as a good personal but others are all daemons which should be destroyed. Wow! What a known concept to the history of human beings. At first the idea was about self sacrifice for the greater good. And yes we are highly engaged by Ninjas, Samurais and heroes and those ordinary heroes which are the best ones which no one knows but they are affecting the life around them in one way or another by bringing pain to themselves or sacrificing themselves for a greater goal or achievement.
To honor the unknown, an idea born! Mehdi and Hussein were the modelers at Proshot which we worked with before and we were creating the game with them. The problem of our flat structure was that we had different tastes and little time and also in all last projects either they were the owner or us and never we worked this much flat. We had a project which we all had equal shares which were the Ninja game which again had an idea when we started and the guys worked at it before we start together. So the main shape of the game was there when we started talking about it. We just adjusted the game play and in many ways it was a copycat. In contrast in gamejam we all wanted something original. The theme was not easy and we were limiting ourselves much by it. As a result we ended up in an idea in last minutes of the first day. A game which 3 protagonists want to grab their own diamonds from the other side of the world and should kill enemies to be able to go there and pick up the diamonds and come back and put themselves and their diamonds in a fire which then would cause the creation of a Phoenix which will kill a similar bird in antagonist side and then will die himself and again lots of those small creatures will appear (those small creatures which we started playing with). It was a game to show the infinite loop of the war between good and evil and the value of self sacrifice and a game with single player and multiplayer involved. Players all should go and pick their diamonds but could help others a little in war (however their paths were different in the map). At the end 3 could see each other when dropping themselves and diamonds in fire. Is this original? :)
We ended up not being able to do this cause we had few hours and thought we could not able to do this all in that small  amount of time (4-5 hours). We wanted a good AI but even the navmesh couldn't be generated well due to design problems in the world. The game needed at least a hand scripted cut scene and two more models which could not become ready.
We also had technical problems due to unity servers being down and a subversion server which didn't work well. Guys told me that we should prepare everything before jam but I failed to listen to them. Actually most of the failures of the team are on my shoulders in many ways. I was the sleepy man unlike most days at work. At the end I found a good set of shurikens to fight with but it was late (No one but me can save myself but it's too late).
Well so we've ended with a multiplayer shooter which now can be downloaded at GGJ's website if you search for personal trap or MindHammerGames. We fixed it's bugs and it will be online there soon.
Back to the gamejam, at the second day I was too sleepy because I had a hard week and also was handling an important business deal during the jam. I was sleepy at the second day and because all of us were not using our own computers during the jam we needed an additional unity and as said before servers were not available so we ended up in a form of pair programming which was not bad but not suited for a gamejam. At the end of the night we went home to finish it all. We slept and woke up at 3AM and worked till 14:00 - 14:30 and then we understood that we could continue for a few more hours too. We gave up before it actually but after knowing it started working again. At 20:00-21:00 we ended it but we choose to don't upload cause the code was the worst which we wrote in our whole life due to mentioned factors and constant changes and low amount of energy even for thinking.
GGJ was a battle between me and myself and the whole week for me. For the team was a battle to learn how to manage stuff better. Actually I told fellows at first day to choose a leader when it was early yet but for the fear of being responsible or failing due to bad leadership from their side or something else which I don't know and cannot judge on the team did not agree on it and I agreed on being not agree with them. Due to talks with GGJ organizers and after knowing that we can fix it later, I uploaded the game on 3AM next morning. Yes I was awake and was doing my work. Actually after the gamejam and the failure I had much of my energy back (strange but true).
We could be much more successful if we had computers ready and working before jam days and if we would choose a leader and a game designer and if I could sleep enough before GGJ. Couldn't wait for the next gamejam. We might actually do an experimental gamejam again soon.

Tuesday, January 10, 2012

SOPA the death of the games community

This is a small part of a post in IQU's blog that you can read here

SOPA: The Death of the Games Community

SOPA. It's an acronym so dirty that to type it causes a collective washing of the Internets mouth. Reaction has been swift and coherent in its singular defiance of proposed Legislation that is global in its reach, idiotic in its understanding of how new media and the internet intersects, and truly naive if it believes we don’t realise it has everything to do with censorship, and will do nothing against the 'rampant piracy' it purports to end.

Read the full post on IQU's blog

Friday, January 6, 2012

Looking back

I was looking back today. I was reading posts on the blog which got visitors from other sources for multiple reasons. unexpectedly a post on NACL feature of unity and the tech's inpact on the future had the most amount of visitors.
But reading the post i saw how small we started and when started writing we diden't own any game development team or ... It was a hubby for us and game development was not a job really. Later on we started MHG and now we are moving. Many of the things said on the blog even on that Native client related post are not correct and there are stuff that are not good to be here when you are working professionally :)
There are two ways to deal with situations like this. the first way is to either delete the stuff or somehow disconnect you company/team from it which we did not choose. The second way is to let them remain for your own record and for others to see your changes in time. everyone is becomming mature and professional in time while working so there is nothing to hide. Surely compared to today we were beginners yesterday and i really hope that  when i look back to years later, This post would look stupid at best.
Game dev started as something that we love for us and now is the job that hopefully would pay our lifes and we try to improve both ourselves and others with. We'll have a blog on our lovely child, MindHammerGames from now on but surely things will be posted here too. Posts like the last post on UnityPark suite and our experiences with it are useful to be there but when i am writing the most fools ideas about trends and future and ... it's better and surely safer to be here :) After all it's much more personal than the blog of the team and gamestudio.

Monday, November 28, 2011

MMO development with unity

As we work on our project mind farming, We experience different things. One of our main obsticles when starting the development was choosing the game engine and networking stuff. we tested multiple MMO middlewares but in that time (about 2.5 years ago) none of them seem ok for a small team like us. mostly client updates were not as fast as we want and iterative development and fast content addition was hard. At this time among them, surely hero engine is the best option if someone wants to choose between those packages to make an MMO. if you want to use one of the popular engines like unity, cry engine or unreal as your client side tech, then you either have to develop your own server side solution or pick one of the existings.
Too much of our time spent in researching the market for a good MMO middleware or a server side solution for unity, after it turned out that we don't want to use one of those MMO only middlewares and we want unity as our client engine for multiple reasons including cross platform ability and ease of iterative development and content pipeline then we had to do something about the server. Different multiplayer games have different needs. we planned for the most complex ones. a turn based game with asynch play is multiplayer and EVE online is too. our game was partly synch and partly asynch. partly real time and partly not that much. so we needed a complete server side solution with support of physics or at least collision detection. we had to find it or build it.
At first the only option was smartfox and photon was a new option. it was obvious that photon is much better so we downloaded the manual and APIs and started reading. we thought of using physx wrappers for .NET and using unity apps in our servers but both attempts were not good for the small team of ours and our budget. we had a big vision with two coders and less than 20K dollars of money in that time. we wanted to start it but not in a path that we know that it's only headache. we waited and other options were comming,
netdog for example was one of them. the problem was that an MMO need much more than message delivery libraries. we needed easy database connectivity and management, load balancing, physics and bandwidth management. the server side logic also had to be developed in C++ which is good in terms of performance but is not a good idea to make gameplay using C++ for a team with 2 coders.
then we heared the news about hero cloud. it was nice. hero engine had all of the server side tech that we want and the client was a good thing. this option was free to start with, so risk was much lower. oh did i mensioned that 2 years gone with these researches and developing small advergames and code frameworks for others as contract job? Hero was good but the client was not unity and they wanted 30% of our money. another 30% was facebook's cut so after facebook announced it we thought that we should think more.
Then we decided to lower our expectations at first release and use a turn based social mechanics engine called roarengine. we started implementing the plugin for using it with unity. it again turned out that it limits us much in terms of game mechanics of the main farm theme enough to not be able to create the original thing that we want. your middleware should help you and break the limitations so if it limits you it might not be a good option.
in middle of that stuff, just in a random way i saw the name of uLink in a post in unity multiplayer forums. what's this? another fast message delivery library? let's take a look! The product was not ready yet. We did not have the money to buy the license and do our other stuff too but i am somehow good in understanding what tech to choose. previously i saw the potential in unity when it was a young mac only product with much less features. i am not a big visionary that foresees the next big thing in tech but i am good at it. my teammates are too. indied i emailed their CEO to see what's going there. the pikko server was really interesting and the description in the site was in one way or another a complete server side MMO middleware. database access and management, bandwidth optimization and network LOD, lobby system, load balancing, fast message delivery and reliable UDP and much more. it was a great description. it changed later a little and some small stuff like facebook integration were removed from the list of the features in the first release but it's still awesome.
Christian and i talked much and he fortunately loved our idea of making a real 3d farming game which is not turn based and is a real game for facebook and social networks. we loved their tech and they loved our idea so we solved other things together. We bought our license and got early access. Now we are moving forward and not only this tech is not limiting our vision but it allowed us to think about implementing things which were not possible with other technologies. even some of them that pikko server offers are not possible in those expensive MMO middlewares. I cannot talk on our experience with MMO middlewares due to their NDA's content but i can talk on unityPark suite that we are happily using.
The experience is really what we wanted. all development is going in unity. Weather server or client script it's written in unity and using all of its framework and physics and collision detection. The database system is great. It's scalable, fast and easy to use. We developed the whole serialization of the game in few days. We also don't have to write too many XML files (like most MMO middlewares) or other sorts of definitions for data to be saved automatically. Instead in a small method we just write debuggable C# code to say what and how should be saved on the database. Content pipeline of the game would be great because we are free to use unity's pipeline and our own database and nothing is dictated. We make the content pipeline of the game as easy as possible. it's just a matter of minutes now to create a new crop type and add it to the system.
In terms of client side features, unity might not have some of the common MMO features in itself but thanks to it's asset store many of those are available for a good price. for example you can find good mesh morphing in asset store which is an important feature for creating customizable avatars. There are packages for weather system and day/night cycles. again it might not be all of that those MMO middlewares offer but you have a cross platform engine which still is listening to it's customers and adds new features fast. it's becomming the industries number one development platform for many types of projects and if you ask me with the addition of UnityPark Suite it's a complete MMO development platform.
Now with Linux support for unity servers, prices will be much lower and server management will be much easier on a single platform. We'll soon publish a document on Unity's asset store for free which tries to help different people to choose the write networking middleware for their projects.

Friday, September 9, 2011

version control

I don't know weather you heard the word version control before or not but I am sure that most of you used it never before. I don't know why no one don't teaches using source control (version control) in first semester in university. I read a great article on reasons for which I forgot the link and name and ... completely (shame on me). Version control software allows you to keep the history of all changes to your project and its files. It also allows multiple people to work on the same project and merge their changes with ease. It works on most network protocols on LAN and on the Internet so working remotely is highly possible. To use version control you don't need experience or anything close to that. Just download an SVN server like visual SVN server and install it on a computer in your LAN or on a machine with static IP on the net, even you can use one of the many free alternatives like sliksvn.com. If the project is open source there are dozens of sites that would be more than happy to lend you some space. A project's container on the server is called a repository and all users and members of the project will connect to it using their clients in order to put their changes on the server (commit) or update their projects (working copies) with the changes other maed to the project (update). As you might noticed we use subversion (svn) as our version control system. There are other systems available with pros and cons which I'll not describe cause you can find much info simply by googling their names. As subversion client, you can use the main/original command line client but there are many clients available for most IDEs. There is a great client for windows explorer called tortoiseSVN that we ourselves use. Before using SVN if someone would ask us: what do you need on your system to make a game we would say, well Unity and visual C# express but now surely we would say: Unity, visual C# express and subversion surely with tortoiseSVN client. The speed would become more than doubled even when only 2 or 3 people are working on the project. Unity users should know that it's better to don't use the SVN clients of IDEs cause there are files that they should version but they are not available on the projects of their ides (i.e models and scenes and prefabs and ...). you can use visual studio's SVN client but don't forget to commit your other changes. We highly recommend tortoiseSVN for windows users. Lucas meijer of unity himself recommended this to us. Unity has a version control software for itself that is called asset server which is $500 for each client but they say that it handles large binary files much better than other solutions which originally created for versioning code (text files). At this time some of the unity file formats are binary and svn can not merge them so if two people change a scene when the second one commits his/her changes changes of the first one will be lost (file will be replaced and not merged). in 3.5 this will no longer be a problem cause unity will use YAML for all of it's file formats which is a popular XML serialization format. they'll also bring in a better integration for subversion and perforce too. A big thanks to robotduck for reviewing and helping me to edit the post (i did not manage to find the time to do all of what he said).