News | Forum | People | FAQ | Links | Search | Register | Log in
Modelling Help\Screenshots\Requests
It has always been difficult to get decent models for quake 1. So a thread where people can get advice on making models and post a work-in-progress for critiques is long overdue.

Any requests for models may well get met with silence. Specific requests will likely stand a better chance; "I'd really like a knight but carrying a shield" might be better received than "we need a mdler to join our mod remaking counter-strike for darkplaces".
First | Previous | Next | Last
I Can 
Recheck my export method when I get home anyway, haven't looked at it in a while. 
Robot Arm 
After adding the robot arm in my map I see this strange overlapping effekt of the cellbox.
In the framegroup there's nowhere a cellbox sliding diagonal, but in game there is.

http://members.home.nl/gimli/Cclaw.gif
http://members.home.nl/gimli/cclaw.jpg

Whayt is it that makes the cellbox warp? 
 
Interpolation? 
Could Be 
This example shows the effect, now the solution if there is.

http://members.home.nl/gimli/celbox.wmv 
 
That looks like interpolation. :) Try turning interpolation off in your Quake engine and see what it looks like. 
 
looks fine to me? what am i missing? it picks the box up and moves it over, then drops it again. also looks cool. 
Lerping From Last Frame To First Frame 
i see it in the video. How to fix it depends on how this animation will be integrated into the level -- obviously right now you have one box vanishing an another magically appearing, so this isn't a complete thing yet. 
 
oh the playback must be broken as it freezes half way for me.
you could try adding two frames, one at the end of the sequence where the boxes shrinks into itself into a single point, and one at the start where it grows from a single point. this way, it would lerp the movement of an invisible single point.
it'll still look goofy because you'll see the box grow and shrink really fast though. 
My Silly Perfectionist 
The animation is a 30 frame static entity, that is a part of two combining conveyor belts.
In the middle there would be another one with an injector uploading the cellboxes.
For one animation the frames are too complicated so I make them in three parts.

The bad point is that I have to make them fit to eachother in place and time.
So the interpolation willem directed to is the cause. I tried to add interpolation 0 at the console but that's wrong ofcourse.

I keep hearing the word lerping.
In the gif file the last frame is the cellbox at the end.
There will be a counterpoint both boxes are on the same place, but I thought I could catch that by letting them drop down into a solid brush while they are moving backwards. 
Frame Counts 
I found the fitzhack version to temper my intention to make the interpolation for the static entity. I just didn't knew it was the engine that had this limit.

The animation rolls much more shaky, but fills in the exact rotation.
The original fitzquake rolls much smoother, but then I keep the hazy frameshades.

I think I keep on to original Fitzquake, as for now only the wheels get creepy.

http://members.home.nl/gimli/vey00.jpg
http://members.home.nl/gimli/vey01.jpg 
Cellbox 
Jack In The Box 
It soon became clear to me that tuning two static entities is a real framejerk, so I combined them.
Reduced the interpolation effect of the conveybelt to the wheels, and then noticed the swing in the middle.
It had become a jolly cellbox.
In Qmle it won't show but in game it's hardly a count.

http://members.home.nl/gimli/conveyc.gif

http://youtu.be/OAi_Sj74BP4 
 
So is it 1000 verts, 2048 tris? I have a model with ~1700 verts loading just fine. 
Verts 
The limits for verts is 2000 almost everywhere, including dos/winquake. The original glquake binary had a reduced vertex limit of 1000, but the released glquake source had this limit restored to 2000. Consequently every source-port has a limit of at least 2000, and there's no reason at all to keep models at 1000. 
 
Ah ok, I got confused by the first post in this thread. 
Btw... 
Just thought I'd mention this: preach's md3 converter is awesome. Thanks for making that thing. :) 
In The Background 
I am sure most new content would never see the light of day without the various coder utilities that work away in the background. I am sure preach would love to see what you have been up to with his model converter! :P 
Well... 
I'm glad it's proving useful, and I'm sure you'll be glad to hear that the next generation of the md3 converter is almost half-done! By which I mean that I've written a module in python which loads and saves mdl format models. I'm just working on a few example models to go with it and then I'll put it out here.

Once that's done, all that remains is to clone the code, adapt it to load md3 files instead, then make the glue code for the conversion. The purpose of all this reinventing-the-wheel is that the glue code will hopefully be clear and easy to adapt, allowing for finer control of the md3 to mdl conversion. For example, if you're making a map object which needs to be aligned on the grid to meet the geometry in the map, you might want to specify the scale used in the conversion of the model coordinates. 
Features 
I was wondering if you don't mind adding some more features:
* BMP skin support (8 bit) I can't get Photoshop to save in that wacky PCX format you use.
* Multiple skins (via the normal text file)
* Update special mdl keys (rotate etc)
* specify names and groups to animation sets (via the normal text file, a comma delimited list) It is awkward viewing stuff in Qme with just a huge list of numbers for frame names. 
In Order 
Yes
Yes
Yes and
Yes

The first one will come from using another python library. The pcx thing was largely chosen because I didn't want the md3tomdl source to have any dependencies on external code, and 8bit pcx was just easy enough to hand-parse. I'll make sure that the examples include some that use the library.

Multiple skins and proper group frames are things that are easy to manipulate with a script and the module that I have now. It's the kind of thing that you'd have to write a whole difficult-to-parse syntax in the "config file" method of the existing tool, so I hope the omission thus far is understandable.

As an example, to set the rotate flag on a model would require the following line added to the script:

����mymdl.flags = 8

If the requirement to know the numerical values of the flags is considered too taxing I might be persuaded to include them as constants! 
Md3tomdl 
@preach, that would be awesome to have those features. It is the last things I use Qme for (multiple skins and model flags) and not having Qme in the pipeline will be awesome.

The config file flag of mymdl.flags is fine with me, is this parameter available in the current version?

I totally understand why the skin / animation names option is missing from the current version. Writing a config file parser is always time consuming. 
Prerelease 
There seems no point keeping the module back when it would already be useful to you, so here it is:

http://www.btinternet.com/~chapterhonour/qmdl.zip

Pop the qmdl folder in your python "Lib" folder. You can then put the following lines in a file called flag.py to add the flag to the mdl file md3tomdl produces.

��from qmdl.mdl import Mdl
��mymdl = Mdl()
��infile = open(r"input.mdl", "rb")
��mymdl.read(infile)
��infile.close()

��mymdl.flags = 8

��outfile = open(r"output.mdl", "wb")
��mymdl.write(outfile)
��outfile.close()


I'd suggest having a short batch file that calls md3tomdl followed by this python script.

Let me know how it works, I've tested with python 3.2, but if you have an earlier version installed it might still work... 
Supplimental 
Some helpful code for renaming frames:

def rename_range(frames, start, name, length):
����for i in range(length):
��������frames[i + start].name = (name + str(i + 1)).encode("ascii")

def rename_frames(mdl, names):
����i = 0
����for name in names:
��������rename_range(mdl.frames, i, *(name))
��������i += name[1]

rename_frames(mymdl, [("walk", 8), ("run", 6), ("stand", 9)])

Essentially you write a list of tuples, where each tuple is the sequence name and length. 
Snakeless 
@Preach, unfortunately I don't have python installed, but I can wait, honestly there is no hurry. :) Plus I am busy creating new skins at the moment, so it will be a while before I am back to exporting models again. 
 
rawr

Sock's mesh, uv and skin and I rigged and posed it.

Thanks again for the converter, preach. Wouldn't have bothered with this stuff without it. 
First | Previous | Next | Last
You must be logged in to post in this thread.
Website copyright © 2002-2025 John Fitzgibbons. All posts are copyright their respective authors.