MV3D Development Blog

January 25, 2007

Posting To LJ Fixes Things

Filed under: Uncategorized — SirGolan @ 4:41 pm

So, a few hours after I made my last post, I figured out the problem– using the PyOgre-ish CEGUI Callback method in Python-Ogre does some serious stack trashing. I have to use the Python-Ogre way of doing it, which is annoying. To specify a callback, you pass two args, a object and an attribute (as a string), so the callback gets called like this: object.getattr(attribute)(args). Annoying.PyOgre did it the sane way.. Just pass a function reference to it. It seemed to work to pass the function as the “object” and a blank string as the attribute, but apparently, that was doing really funky stuff that wasn’t immediately obvious. [I mean, really funky. I was making the first line of the callback function be a “return” (which should end the function there), but the rest of the function was being run!]

Anyhow, while I’m recompiling Python Ogre on Linux, I really wanted to take a moment and ask some of the frequent MMORPG players about this statement I saw on a MMORPG related forum:

“In [MMORPG Engine], items are expected to exist only in inventory, so they have an icon but not a display context. Items are also only created in the inventory manager, whereas the world manager needs to know about objects that are in the 3d world. ”

Is this the norm? Do you have stuff in your pockets that you can’t just drop on the floor in most MMORPGs? If so… Odd. I can sort of see some reasoning behind it– you don’t want people leaving junk all over the place. Seriously? Why not have a garbage collector that picks up all the stuff that’s been sitting around?

Someone in that thread commented that allowing people to drop stuff on the ground has lead to item duplication issues. Maybe that’s another reason against it. Seriously? It is pretty sloppy code if you can duplicate items through dropping and picking them up. In MV3D, an item doesn’t leave the game if you pick it up. (um. aside from the fact that there is currently no ‘pick up’ or ‘drop’ code at all in MV3D yet) You pick something up, and the same data that represented the object still represents the object. Doesn’t matter if you stuff it in your backpack or anything– it’s still the same object.

That’s all for now, though noticing ’s recent post, feel free to ask me to show you a picture of what I saw on my way to work this morning. :)

January 24, 2007

Still here..

Filed under: Uncategorized — SirGolan @ 2:07 pm

I’m still here. Still working on things. Mostly, I’ve been split between trying to get Python-Ogre to compile & run on Linux (it runs now– sorta), and converting MV3D to work with Python-Ogre (in Windows). It has been very frustrating to the point that I could have put together my own Python Ogre wrapper by this point. Right now, I have an “Unidentifiable C++ exception” that is causing the game to crash when you select a PC to use.

I haven’t been able to give MV3D my full attention lately due to various other things going on, but still, I have spent a lot of time on this one task that should have been simple.

January 11, 2007

Client Progress

Filed under: Uncategorized — SirGolan @ 11:37 am

So, I now have a version of the client that gets to the login screen running on Windows. I just updated it to the latest Python-Ogre release as well. Unfortunately, the MultiColumnListBox in the select PC screen bombs out.

Part of the problem is that for some reason, the GUI skin I had been using (WindowsLook) doesn’t work in the new version. Because of that, I have to go through all the places where GUIs are defined and change them over to the TaharezLook skin (which I’m not too keen on).

One reason this took so long is that in between the version of Ogre that PyOgre used (1.2.0) and the version that Python-Ogre uses (1.2.4), a new user input system has been included called OIS. All the keyboard and mouse handling had to be converted to that new input system. There were also lots of other little things that had to be changed since Python-Ogre does a lot of things differently from PyOgre.

Meanwhile, the server that runs Trac and SVN seems to be acting up right now. Web pages are giving Internal Server Errors, and SSH’ing to it spits out the MOTD and then disco’s you. I’ll have to check on it when I get home, but this means I can’t work on the remaining features of the Asset Web App (creating/deleting asset groups, deleting assets).

Overall, I’m getting rather frustrated with the lack of progress. I’ve spent a lot of time trying to get Python-Ogre working on Linux (with no success). I’m considering going back to PyOgre and dealing with its limitations for 6 months or so until the Python-Ogre guys (or whoever else) figures out a better solution.

Once the clients are back in order, I’ll be in desperate need of some 3D models. Anyone out there any good at creating low poly humanoid models? I know how, but suck badly at it.

January 7, 2007

Go-go gadget UPS!

Filed under: Uncategorized — SirGolan @ 5:24 pm

Not much to say about MV3D just now. I’ve been working on some uninteresting parts and trying to get through some of the tickets for the next release. On the client side, I need to wait until Python-Ogre works in Linux to do anything there. I have been hacking away at getting the Windows client w/ Python-Ogre working. It runs, but you don’t currently see the UI or mouse pointer.

I finally got around to installing the 3kva UPS for my home servers. It would have been simple to install if the 20A circuit had a 20A outlet on it (the ones which accept plugs where instead of two parallel contacts, one is perpendicular to the other). So I had to replace the outlet and had just been procrastinating about going to Home Depot to buy one.

I think with the current load (5 servers), it’ll give me about 20 minutes, but I’ll have to plug in to the serial port on it to verify that. 20 Minutes would be good. if I can run a serial cable over to the other side of the basement(*), I could set up all the servers to power down before the UPS batteries run out. apcupsd is your friend.

Hmm, now I should probably also think about data backup. I’ve been relying on RAID to save me in the event of a hard drive failure, but I should probably go a little further than that. It would be nice to have one more server class machine since has been asking for an Exchange email server, and I’ve been annoyed with decentralized authentication for windows machines here, so active directory would be a good benefit.

Am I nuts to be installing a 3kva UPS and thinking about having active directory and exchange in my basement? :) Ok, running cat5 to the kitchen and bedroom are probably higher on the list than that.

For anyone curious:

  • Firewall: Linux / Pentium (or P2?) / L2TP VPN (not 100% working at the moment)
  • Mail and Web server: Linux / P3 / Raid
  • File server and multimedia player: WinXP / P3 / 150GB / DVDRW drive (yes, 150GB is small for a file server these days..)
  • MV3D Alpha Server: Linux / 2x P3 Xeon / Raid (CPQ DL380 G1)
  • MV3D Dev Server: Linux / 2x P3 Xeon / Raid (CPQ DL380 G1)

I can also put video and audio through to any one of 3 TVs from: DVD player, VHS, File server, my desktop, a laptop, or a video camera via video switches in my office.

While I’m blabbing about my house-related geekery, I might as well have a todo list:

  • Extend network into the bedroom, kitchen, and living room.
  • Upgrade from b -> g wireless (the access point is in the basement unopened)
  • Install wall jacks instead of regular cable ends for all the ethernet.
  • Get a bigger switch… Should have taken a few of the 48 porters that my last company junked. :(
  • Install X10 stuff and write some python code to do cool stuff with it.

  • Upgrade the quality of the video/audio system and run outputs to the other office and the kitchen.
  • Nagios - Network monitoring system so that I get paged when a server is down or out of disk space or whatever
  • More space on the file server.. I have the drives, but the server can’t handle them.
  • Find some way to make the home theater (video projector, screen, and laptop) less time consuming to set up yet it must remain portable between the bedroom and livingroom. Find a PCMCIA soundcard that can do surround as well. :)
  • Add another NIC into the firewall so that there is a DMZ for public hosts (mail/MV3D servers)

* My basment is cool and has a nice built in server rack (at least, that’s what I use it for) off in a corner, but there’s only 3 sets of outlets, and they are all on the other side from the servers. I’ll eventually run a real outlet over to the server area, but for now, a 20A extension cord will do. The UPS is by the outlet, which is about 35′ (as the cable goes) from the servers. Unfortunately, it doesn’t have a network interface either.

December 26, 2006

aqqqqqqqqqqqqqqqqqqqqqqsw (this subject brought to you by my cat)

Filed under: Uncategorized — SirGolan @ 10:19 pm

There has definitely been more frustration lately. I’ve been trying all week to get Python-Ogre to compile. It’s a very new thing, and the developers have concentrated on Windows so far. The good thing is that they’ve been in constant communication with me to work through the problems– even on Christmas day! It is getting closer. The cool thing about Python-Ogre is that it uses Py++ and aparently, Py++ automatically wraps C++ code based on rulesets you define. That way, as long as Ogre sticks to its coding conventions (i.e. function names and such), then additions to Ogre will be automatically Pythonitized. But, the problem is getting things to compile. Once again, since it’s a new project, there is little to no documentation. Not much in the way of helpful code comments either, unfortunately. This has really slowed my progress this week as I broke my PyOgre installs on Windows AND Linux trying to get this stuff working. So unless I use one of my laptops, I don’t have a working MV3D client. Yes, I said Python-Ogre is working on Windows.. However, there are a lot of little tweaks that need to be done to get MV3D working on it. Part of the problem is that it is for the newest version of Ogre, and there are a bunch of API changes there. But it also doesn’t yet have the cool transformations of 3 tuple -> Ogre Vector3 classes and things like that. I’ve mostly compartmentalized my Ogre code, so there aren’t all that many places where those things come up luckily. Anyway, there is still more work to do. The Windows client (where I’ve been doing the updating) doesn’t even render the first frame yet….

On the flip side, my web-based Asset Tool is coming along well. By well, I mean it is almost to a good stopping point. It is usable right now. You just can’t delete assets and asset groups or create asset groups. There also aren’t yet extra properties for the various sub-types of assets (but the structure is there, so adding them is fairly simple). There is something I find really cool with the way the app works. It is a web app, but it connects to a MV3D server to build the pages. Yay for Twisted! One day, I want to make a web app that works like an in game web-cam, but something that may be more useful is an app like the Asset one that allows you to edit object properties instead. That would be pretty useful. Either way, it is very cool to have a web app the connects to a running game server.

I think with the broken clients, I’ll try and hit on the server things that I’ve been putting off: DB Performance, Area Sharing between servers, and stuff. If I get bored, I can always go back to Windows and continue porting to Python-Ogre.

This week, I happen to have a video projector and have set up a home theater for it. Naturally, I had to log in to MV3D on the 6′ x 6′ screen. It was pretty cool, though it would have of course been much better if there was actually something to do in the game other than walk around and jump into the water.

Hope everyone’s having a good holiday season!

December 21, 2006

Frustration, cha cha cha.

Filed under: Uncategorized — SirGolan @ 10:35 am

I was able to speed up the Noise generator by caching the pseudo random numbers. It seems like random.seed() is very slow, and I was calling it about a billion times. Anyway, the whole thing is 10x to 100x faster now. Not quite fast enough for generating a 2d noise image every frame, but usable now.

I got the server application to run on Windows. You don’t get the ability to use a database (though I suppose if I were to install MySQL and its Python bindings, it would probably work on windows.) I also have some Windows screen shots (the water is actually blue!). These detail my playing around with the in game editor:

A cube and a few robots floating in water:

And my favorite– a picture of a fish:

Things were very stable, and therefore, I updated the alpha server and made up a Windows client build for all the testers.

Why am I frustrated, you may ask? In my last post (or the one before?) I mentioned that I figured out how to do bounding boxes for objects. Yes, it’s true, I did, and it was going to be splendidly easy… if the PyOgre folks had remembered to wrap the OgreWireBoundingBox class, which they hadn’t. After giving up on that, one of the next things I needed to do is to have some way of quickly modifying or creating textures in Ogre. I’ll be creating a sort of paint program so you can modify the placement of various textures on the terrain (rock vs dirt vs road). To do that, I need to display the image you are painting to (duh), and for that, it needs to be made into a texture in Ogre. Digging through the PyOgre code, PyOgre wiki and forum, I came up with some code that may be able to give me access directly. It even almost worked. Unfortunately, in the most recent Windows release of PyOgre, the code is not wrapped. Ok, fine, since it was on Linux, I should be able to manually build a newer version of PyOgre. Nope. Many errors resulted. Ok, try it in VC++. Same result. After digging around on the forum, I found this post by the creator of PyOgre. So this means, no more PyOgre updates (there haven’t been any in months anyway). He mentions Python-Ogre, which I have been ignoring even though they’ve been stealing the PyOgre forum a lot lately. Basically, my only option at this point is a) maintain PyOgre myself (while I do have a good amount of experience with SWIG, I am not good ad building code on Windows), or b) switch to Python-Ogre. Looks like it’s option B. They claim that you only have to make a few adjustments. We’ll see. I was finally able to get PythonOgre running its demos in Windows this morning after quite a few hours of annoyances. We’ll see how hard it is to make it work in Linux. Though, before going through that trouble, I will be learning enough of Py++ to determine if WireBoundingBox is wrapped (it should be since Py++ wraps everything supposedly), and if the texture related stuff will work at all.

I may still have to write my own little Python extension.. Something like:

char *Convert(void *a) {return (char*)a;};

Unless Py++ is friendlier than SWIG when it comes to pointers. It’d probably be good to do something simple like that as a basis for other C++ Python extensions I’ll have to write later (for the purpose of speeding things up), but once again, while this may be simple on Linux, I still hate building things on Windows. Maybe VC++ will make it easier, I don’t know.

December 18, 2006

Getting noisy in here.

Filed under: Uncategorized — SirGolan @ 12:28 pm

I implemented a Perlin Noise function (1D or 2D) in Python which is pretty cool, albeit slow as molasses. It should be upgraded to handle 3D and 4D (and to be faster..), but for that, I’ll need to brush up on my Trilinear Interpolation. Have not done tlerping for a while, but I did just notice that article has a pseudocode link. However, for 4D, I’d need quadlinear interpolation (if that’s what you call it). Anyway, what does all of this geek talk do for MV3D? Well, for one, it generates realistic looking terrain:


It can do many other things such as moving clouds, flowing water, and textures that are extremely small to download. Check out Ken’s site for more fun things. Something to mention is that in the first image, there are 4 little dots somewhere in approximately the middle of that landscape– those are the other PCs. :) Also, there is a terrain chunk missing in the corner furthest away from the camera. This is just because it’s out of the view range. Anyway, you may say “But Mike, why would you want to rebuild the wheel on terrain generated by Perlin Noise when 3rd party tools are out there that are extremely good?” The answer is that using those tools will still work, but since my noise function can incorporate arbitrary edits to the output seamlessly and can run inside the client and server, one can send a huge portion of terrain to the client over the network by just sending the parameters to the noise generator along with the edits to apply. That could save tons and tons of bandwidth. The noise generator just needs to be faster.

In other news, I’ve done a lot of work on the editor this weekend and last week. I hope to have a usable version out to the testers some time this week. It is pretty solid right now. All of the buttons work at this point including the properties button and deleting objects. I just finished a properties screen for Biped objects, and will either move on to one for Box objects (so people can change the model associated with them and start some basic world building), or terrains (so that you can adjust the terrain heights). Schubaal helped me out with a better looking image to denote object selection, then this morning, I looked into wire frame bounding boxes a little more closely, and I may be able to use them after all. Schubaal’s image would still be used, just I would also add an additional option to turn on bounding boxes.

Update: It turns out that by taking a good look at how blerping (bilinear interpolating) works, I was able to extend that to trilinear and quadrilinear, so now my fun noise generator can do up to 4D. Really, there should be some way to do Xlinear interpolation (i.e. any number of dimensions), since the algorithms are the same just with added dimensions. For some reason, though, I haven’t been able to wrap my head around that one yet. However, I don’t see the need for >4D, do you?

December 11, 2006

Behold my awesome programmer art!

Filed under: Uncategorized — SirGolan @ 9:55 am

I solved the item selection problem for now thanks to a little help from The Gimp..

No funny comments on where the center of the selection image hits. Well, maybe if they are particularly funny…

All silliness aside, I would like to mention that Ogre really does make many things very easy. It still falls back to my earlier comment that while Ogre isn’t trying to be the all in one game utility that Crystal Space is, it is excellent at what it does do. Making that image pop up was pretty easy and was under 20 lines of code, I think.

I also made progress in making useful move and rotate functions. You can drag things around with the mouse and stuff. I really think they will need to move with you when you walk as mentioned. The fun thing to do now is to select your PC and use the mouse to fly yourself around.

I’m starting to work on the “Add Object” function. For that, I need to add all the object types (biped, terrain, white block, and so forth) as assets and generally make some way to select assets. Luckily, an asset selector that was sufficiently generalized will help elsewhere. Especially if you can tell it to only allow you to select assets of a given type (i.e. images only). After that, I’ll probably hit on either deleting objects (which I’m not certain is 100% supported in the code), or the item properties button.

In other news, the amazing Rik Vargard is back to help out with art. So, this may be the end of programmer art. Rik made pretty much all of the 2d and 3d art in Siegium, including the website. He was also on the MV3D team prior to that and is an extremely talented artist.

Oh yeah, if you are interested, here’s my laptop/server hard drive shown next to a normal server hard drive:

December 8, 2006

Are you bored of world editing yet?

Filed under: Uncategorized — SirGolan @ 2:00 pm

Hopefully, I’ll update this weekend or early next week with some screen shots of the world editor. There still isn’t too much to see really. The toolbar code is more or less finished, and I have a few plugins done– select item from a list and select objects by clicking on them. I also made some button graphics and got them to work. The screenshots are worth it just to see the horrible programmer art on the buttons. :) I’m starting to work on an object movement plugin and then will do object rotation. At that point, the tools will at least start to be useful because you’ll be able to move objects around and rotate them. It won’t be incredibly useful until there is a “create object” button. For that, I need an asset browser and I’ll need to do some work on associating object code with assets.

One problem that I’ve been trying to solve all week is how to signify which objects are selected. Part of the problem is that not all selectable things have a visual representation or even a position. The other part is that I can’t see an easy way to do it in Ogre. My first idea was to display the object’s bounding box. It would be crude, but it would work on things large and small (though not on invisible things). Unfortunately, it seems the code needed to draw a box on the screen in Ogre is several hundred lines long.. And the example is in C++, so it’s not clear if I can do it in Python. So that’s not worth it. Also, you can turn on drawing bounding boxes, but it’s either for all objects or none.

The next thought was to make the selected object brighter or semi-transparent. I can find no way to do that within Ogre. I briefly considered attaching some sort of particle effect to whatever you selected, but if you are selecting 500 things in an area, that could get a little slow. So it looks like I’ll have to resort to making some sort of semitransparent image that I’ll stick on things that are selected.

In any case, showing what objects are selected is fairly important. I’m considering making each object in charge of figuring out how to select and deselect itself– as in it’ll have to put up the image to show it is selected. That way, things without a position can show their selected status in some other way.

As a fun aside, I recently ordered some brand new servers from HP. They just came out with a new “generation” of servers, so this was my first time seeing them. One of the features of the new generation is that you can stuff more drives into them. 6 drives in a 1U (1 3/4″) high server is very impressive, and I’ve been wondering how they pull that off. Today, some of the hard drives came in. They are freaking laptop hard drives! I’m not so sure I like that idea as I usually end up with a big stack of laptop hard drives on my desk that have failed. I guess that’s what RAID is for though.

December 4, 2006

Edit My World

Filed under: Uncategorized — SirGolan @ 12:39 pm

I fixed the bugs in the OctreeArea and moved on to the in game editor. I started to work on some of the multi-server features of the OctreeArea, but didn’t really test them. Mostly, I wanted to make sure that it worked in a master/slave server situation. It does now. I definitely have some thoughts on how to divvy up the octree nodes amongst the servers simulating them, but that may not be the hard part of the whole thing. The hard part will be figuring out how to quickly switch an object’s master server because when a node changes servers, all objects in that node need to change servers with it (otherwise, there is little or no performance gain).

The more interesting part of this update follows. I’m working on the user interface that will allow people to put the game worlds together. This is something that has always been planned to exist within the actual game as opposed to having a separate application. I have some fairly well defined ideas on how it’ll be set up, but I want to open it up to any suggestions from people who read this. So if you have any opinions, speak up now.

I’ve written up some basic ideas here, and asked on the forums here. But in simple terms, let me explain what I have in mind.

It’ll sort of be like a paint program. You have a toolbar that contains various icons (like the “pencil”, “paint can” and “air brush” of a paint program). The tools are organized by sections such as: select, object, area, and realm. Select will contain various means of selecting things (by clicking on them in your view, select from a list, and so on). The others will just have editing related to those game elements.

All game elements will also have a “properties” window. This is something very similar to what you get in windows when you right-click and select properties. Except, the purpose is to be able to manually edit all the properties of the item.

The main priorities for this are:

  • Ease of use
  • Speed of creating things
  • Flexibility and extensibility (I should mention that the toolbar uses a plugin architecture)

Anyway, what functions would you like to see? What things do you think would work well? What features would help you creating a 3D virtual world?

« Older PostsNewer Posts »

Powered by WordPress