One More Caveat
#342 posted by Preach on 2012/05/01 22:29:40
If you are using darkplaces then you will also notice the effect appears to cease working. Now we are sort-of performing a hack here so it isn't that surprising that response is mixed. It's also worth noting that what darkplaces is doing is not entirely terrible(tm).
Lets break down why in most quake engine we get varying brightness by changing vertex normals. I believe this is accurate but correct me if you know better...Quake has effectively a hack to make vertex normals work, by rendering as if there is a single bright source of light coming from a fixed direction. You get brightest light levels by having a normal directly facing that direction, and darkest by facing away from it. You can observe this by rotating 360 degrees on the spot and watching the shading vary on the viewmodel.
Darkplaces rejects this and instead uses all sources of dynamic light in the scene as origins for vertex normals to be evaluated against. This means that the twinkle effects are not visible most of the time, but if you run the quad cheat you can get them to render.
#343 posted by necros on 2012/05/01 23:33:20
yeah, that was the first thing i checked after seeing it work in QS. :)
of course, if you're running in DP, it's not much extra work to include a q3 shader script to take the place of the flickering vertices.
Something Interesting
#344 posted by necros on 2012/05/03 07:18:18
don't know if everyone knows this already; this is mainly useful if you're just modding an already made model:
if you convert a .mdl in a .md2 with q2mdlr9b and export a frame, you will be able to import the md2 into max (with http://www.scriptspot.com/3ds-max/scripts/quake-ii-md2-importer ) whil preserving the original q1 skin mapping.
from there you can add to the uv map with normal max tools and then export following the md3 -> mdl route. nice not to have to start from scratch.
Wow
#345 posted by ijed on 2012/05/03 22:12:55
Missed 30 odd posts there.
Did you get an FBX exporter or workaround Necros? As far as I can remember I'm using the default one from Max2010.
Those pickup models look great - we also did this, but ours are fairly un-artistic :(
#346 posted by necros on 2012/05/03 22:39:27
nah, couldn't figure it out.
i've since gotten an alternative method which works fine using npherno's md3 importer and preach's md3->mdl converter.
I Can
#347 posted by ijed on 2012/05/03 22:44:48
Recheck my export method when I get home anyway, haven't looked at it in a while.
Robot Arm
#348 posted by madfox on 2012/05/04 21:26:57
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?
#349 posted by JneeraZ on 2012/05/04 21:54:09
Interpolation?
Could Be
#350 posted by madfox on 2012/05/04 22:06:57
This example shows the effect, now the solution if there is.
http://members.home.nl/gimli/celbox.wmv
#351 posted by JneeraZ on 2012/05/04 22:10:05
That looks like interpolation. :) Try turning interpolation off in your Quake engine and see what it looks like.
#352 posted by necros on 2012/05/04 22:33:07
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
#353 posted by metlslime on 2012/05/04 22:41:11
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.
#354 posted by necros on 2012/05/04 22:43:29
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
#355 posted by madfox on 2012/05/04 22:58:29
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
#356 posted by madfox on 2012/05/08 08:42:10
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
#357 posted by madfox on 2012/05/08 08:48:52
Jack In The Box
#358 posted by madfox on 2012/05/11 08:14:53
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
#359 posted by necros on 2012/05/15 00:41:33
So is it 1000 verts, 2048 tris? I have a model with ~1700 verts loading just fine.
Verts
#360 posted by Preach on 2012/05/15 01:08:30
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.
#361 posted by necros on 2012/05/15 01:10:35
Ah ok, I got confused by the first post in this thread.
Btw...
#362 posted by necros on 2012/05/16 03:28:43
Just thought I'd mention this: preach's md3 converter is awesome. Thanks for making that thing. :)
In The Background
#363 posted by sock on 2012/05/16 19:30:01
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...
#364 posted by Preach on 2012/05/16 22:05:20
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
#365 posted by sock on 2012/05/16 22:32:19
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
#366 posted by Preach on 2012/05/17 00:37:04
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!
|