Rune Central http://runequake.com/forums/ |
|
Hello there ;) http://runequake.com/forums/viewtopic.php?f=9&t=524 |
Page 1 of 1 |
Author: | demon [ Wed Sep 29, 2004 4:10 am ] |
Post subject: | Hello there ;) |
Im new to this forum, allthough some her might know me from Qsg as reckless I have been twiddeling a lot with joe's engine over a little year or so, and added some glow effects and md3 model support "just stuck a bit on getting dynamic lighting to work on them but its allmost there" . The glow effects are from mhquake but modified a lot by me, and can be turned on/off so if someone find them lame its not that big a problem md3 support is working great though and adds a lot to it because its easier to make good looking custom models for md3 than the old mdl format only bug is the one above, but if joe can use my code feel free to do if the above has any interrest leave me a note and ill give ya a link for the source greetz |
Author: | sputnikutah [ Sat Oct 02, 2004 9:08 pm ] |
Post subject: | |
ya im having trouble getting the md3 model code from QURE to work properly... |
Author: | demon [ Sun Oct 03, 2004 5:07 pm ] |
Post subject: | |
i fixed that it works like a charm now only thing still not completely working are shadows & dynamic lighting "need a struct replacement for the lookuptable" here's my current code for the md3 renderer Code: void R_DrawQ3Model(entity_t *e)
{ int i, j, k, lnum; int frame; int lastframe; int vertframeoffset; int lastvertframeoffset; float alpha; float blend, iblend; float l, add, radiusmax = 0.0; vec3_t l_v, vec, normal; vec3_t dist, ang, dlight_color; model_t *clmodel; md3header_mem_t *header; md3surface_mem_t *surf; md3shader_mem_t *shader; md3st_mem_t *tc; md3tri_mem_t *tris; md3vert_mem_t *verts, *vertslast; if (!gl_notrans.value) { // allways true if not -nehahra model_alpha = currententity->transparency; if (model_alpha == 0) { model_alpha = 1.0; } } else { model_alpha = 1.0; } alpha = (currententity == &cl.viewent && gl_mtexable) ? ( (cl.items & IT_INVISIBILITY) ? gl_ringalpha.value : bound(0, r_drawviewmodel.value, 1) ) : model_alpha; if (alpha < 1.0) { glEnable (GL_BLEND); } //md3 interpolation clmodel = e->model; e->frame_interval = 0.1f; if (e->pose2 != e->frame) { e->frame_start_time = realtime; e->pose1 = e->pose2; e->pose2 = e->frame; blend = 0; } else { blend = (realtime - e->frame_start_time) / e->frame_interval; if (blend > 1) blend = 1; } iblend = 1.0 - blend; // get lighting information // make thunderbolt and torches full light if (clmodel->modhint == MOD_THUNDERBOLT) { ambientlight = 210; shadelight = 0; r_lightlevel = true; } else if (clmodel->modhint == MOD_FLAME) { ambientlight = 255; shadelight = 0; r_lightlevel = true; } else { // normal lighting r_lightlevel = false; ambientlight = shadelight = R_LightPoint (currententity->origin); for (lnum = 0 ; lnum < MAX_DLIGHTS ; lnum++) { if (cl_dlights[lnum].die < realtime || !cl_dlights[lnum].radius) continue; VectorSubtract (e->origin, cl_dlights[lnum].origin, dist); add = cl_dlights[lnum].radius - Length (dist); if (add > 0) { if (gl_vertexlights.value) { if (!radiusmax || cl_dlights[lnum].radius > radiusmax) { radiusmax = cl_dlights[lnum].radius; VectorCopy(cl_dlights[lnum].origin, vertexlight); } } VectorCopy(bubblecolor[cl_dlights[lnum].type], dlight_color); for (i=0 ; i<3 ; i++) { lightcolor[i] = lightcolor[i] + (dlight_color[i] * add) * 2; if (lightcolor[i] > 256) { switch (i) { case 0: lightcolor[1] = lightcolor[1] - (1 * lightcolor[1]/3); lightcolor[2] = lightcolor[2] - (1 * lightcolor[2]/3); break; case 1: lightcolor[0] = lightcolor[0] - (1 * lightcolor[0]/3); lightcolor[2] = lightcolor[2] - (1 * lightcolor[2]/3); break; case 2: lightcolor[1] = lightcolor[1] - (1 * lightcolor[1]/3); lightcolor[0] = lightcolor[0] - (1 * lightcolor[0]/3); break; } } } } } // calculate pitch and yaw for vertex lighting if (gl_vertexlights.value) { apitch = currententity->angles[0]; ayaw = currententity->angles[1]; if (!radiusmax) { vlight_pitch = 45; vlight_yaw = 45; } else { VectorSubtract(vertexlight, currententity->origin, dist); vectoangles(dist, ang); vlight_pitch = ang[0]; vlight_yaw = ang[1]; } } // clamp lighting so it doesn't overbright as much ambientlight = min(128, ambientlight); if (ambientlight + shadelight > 192) { shadelight = 192 - ambientlight; } // always give the gun some light if (e == &cl.viewent && ambientlight < 24) { ambientlight = shadelight = 24; } // never allow players to go totally black if (clmodel->modhint == MOD_PLAYER) { if (ambientlight < 8) { ambientlight = shadelight = 8; } } } if (clmodel->modhint == MOD_PLAYER && r_fullbrightskins.value) { ambientlight = shadelight = 128; r_lightlevel = true; } header = (md3header_mem_t *)Mod_Extradata (currententity->model); if (*(long *)header->id != MD3IDHEADER){ Con_Printf("MD3 bad model for: %s\n", header->filename); return; } glPushMatrix(); //interpolate unless its the viewmodel if (e != &cl.viewent) { R_BlendedRotateForEntity (e, 0); } else { R_RotateForEntity (e); } surf = (md3surface_mem_t *)((byte *)header + header->offs_surfaces); for (i = 0; i < header->num_surfaces; i++) { if (*(long *)surf->id != MD3IDHEADER){ Con_Printf("MD3 bad surface for: %s\n", header->filename); } if (surf->num_surf_frames == 0){ surf = (md3surface_mem_t *)((byte *)surf + surf->offs_end); continue; //shouldn't ever do this, each surface should have at least one frame } frame = e->frame; frame = frame%surf->num_surf_frames; //cap the frame inside the list of frames in the model vertframeoffset = frame*surf->num_surf_verts * sizeof(md3vert_mem_t); lastframe = e->pose1%surf->num_surf_frames; lastvertframeoffset = lastframe*surf->num_surf_verts * sizeof(md3vert_mem_t); //get pointer to shaders shader = (md3shader_mem_t *)((byte *)surf + surf->offs_shaders); tc = (md3st_mem_t *)((byte *)surf + surf->offs_tc); tris = (md3tri_mem_t *)((byte *)surf + surf->offs_tris); verts = (md3vert_mem_t *)((byte *)surf + surf->offs_verts + vertframeoffset); vertslast = (md3vert_mem_t *)((byte *)surf + surf->offs_verts + lastvertframeoffset); // if shader binds to e->skinum // it will fuck up modeltextures // so use currententity instead if (surf->num_surf_shaders!=0) { GL_Bind(shader[(currententity->skinnum%surf->num_surf_shaders)].texnum); } else { GL_Bind(0); } // normals and vertexes come from the frame list // blend the light intensity from the two frames together // yeah like fuck it does that right :( if (blend >=1) { l = R_LerpVertexLight ((int)verts->normal, (int)verts->vec, blend, apitch, ayaw); l = min(l, 1); } else { l = R_GetVertexLightValue ((int)verts->normal, apitch, ayaw); l = min(l, 1); } if (!r_lightlevel) { for (i=0 ; i<3 ; i++) { l_v[i] = lightcolor[i] / 256 + l; } glColor4f (l_v[0], l_v[1], l_v[2], alpha); } if (blend >=1) { glNormalPointer(GL_FLOAT, 6 * sizeof(float), (float *)verts->normal); glEnableClientState(GL_NORMAL_ARRAY); glVertexPointer(3, GL_FLOAT, 6 * sizeof(float), (float *)verts->vec); glEnableClientState(GL_VERTEX_ARRAY); glTexCoordPointer(2, GL_FLOAT, 0, (float *)tc); glEnableClientState(GL_TEXTURE_COORD_ARRAY); glDrawElements(GL_TRIANGLES, surf->num_surf_tris*3, GL_UNSIGNED_INT, (int *)tris); glDisableClientState(GL_NORMAL_ARRAY); glDisableClientState(GL_VERTEX_ARRAY); glDisableClientState(GL_TEXTURE_COORD_ARRAY); } else { glBegin(GL_TRIANGLES); //for each triangle for (j = 0; j < surf->num_surf_tris; j++) { //draw the poly for (k=0; k < 3; k++) { //interpolated vec[0] = verts[tris[j].tri[k]].vec[0] * blend + vertslast[tris[j].tri[k]].vec[0] * iblend; vec[1] = verts[tris[j].tri[k]].vec[1] * blend + vertslast[tris[j].tri[k]].vec[1] * iblend; vec[2] = verts[tris[j].tri[k]].vec[2] * blend + vertslast[tris[j].tri[k]].vec[2] * iblend; normal[0] = verts[tris[j].tri[k]].normal[0] * blend + vertslast[tris[j].tri[k]].normal[0] * iblend; normal[1] = verts[tris[j].tri[k]].normal[1] * blend + vertslast[tris[j].tri[k]].normal[1] * iblend; normal[2] = verts[tris[j].tri[k]].normal[2] * blend + vertslast[tris[j].tri[k]].normal[2] * iblend; glTexCoord2f (tc[tris[j].tri[k]].s, tc[tris[j].tri[k]].t); glTexCoord2f (tc[tris[j].tri[k]].s, tc[tris[j].tri[k]].t); glVertex3fv(vec); glNormal3fv(normal); } } glEnd(); } surf = (md3surface_mem_t *)((byte *)surf + surf->offs_end); if (alpha < 1.0) { glDisable (GL_BLEND); } } glPopMatrix(); } hope this is to some help |
Author: | sputnikutah [ Sun Oct 03, 2004 9:21 pm ] |
Post subject: | |
does it matter if u put md3header_t *model = Mod_Extradata(e->model); near the top before the lighting information? Tei's code is similar to this, QMB and others are completely incompatible with JQ, i think.. ill try to encode this... ill let u know if i get any lighting on the alias md3 models, color can come next, ill be happy if i see anything but errors |
Author: | sputnikutah [ Mon Oct 04, 2004 12:07 am ] |
Post subject: | |
hmm, well i got the code implemented without any erros but how do i test the models now? |
Author: | demon [ Mon Oct 04, 2004 2:34 am ] |
Post subject: | |
nice. hehe allready made a pak with the nessesary model stuff got it on ftp but the pak's rather large "hope you dont mind" includes everything needed for max eyecandy ftp://80.162.236.139:21 login anonymous no password for the smallest download choose this mini_pak.zip or if you prefer the full thing demonquake_full_pak.zip warning the full pak is in exess of 130 megabyte love to hear if you get by this dynamic lighting buggah its been driving me crazy |
Author: | demon [ Mon Oct 04, 2004 2:41 am ] |
Post subject: | |
oh almost forgot you might have a look at the source for demonquake because i load the shaders for the md3 models from two seperate dirs under textures one for weaponmodels and one for bsp models i also enabled a few flags in the model code to have rotating weaponmodels & such so if theres anything you like feel free to use |
Author: | demon [ Thu Oct 07, 2004 2:20 pm ] |
Post subject: | |
any progress yet. Still working on the fix but is a drag tried splitting up the renderer function to work more like normal quake does but is a drag its working however but still the dynamic lighting is a pain in the ass But succeded in adding shadow volumes on them. I dont think you want that feat though "major fps drop" in some scenes im down to 10 fps |
Author: | sputnikutah [ Fri Oct 08, 2004 3:43 am ] |
Post subject: | |
well, i implemented some .md3 code.... tried tie's, then qmb, yours etc....... the models load up not the skins, (need to add skins to folder) but then i got freezes in mid game like after 20 minutes of play... tried to fix that while adding decals from projectile contact to bps then all sh!t hit the fan.. and reverted back to a base compile b4i started adding md3 code so im back to square 1, functionable compile, no progress :< all good, rather proceed with stability and get it right instead of quickly making bugs I just need to learn a little more openGL coding |
Author: | demon [ Fri Oct 08, 2004 10:18 am ] |
Post subject: | |
me2 i must admit *G* but nice to hear some progress hmm the crashy thing i dont get maybe take a look at demonquake source gl_md3.c gl_md3.h and where i call it in gl_rmain "i use a different approach than qmb "not called in r_drawaliasmodels" Good luck with getting it to go |
Author: | Jozsef [ Mon Oct 18, 2004 3:43 pm ] |
Post subject: | |
i'd be interested in seeing the code, but cant reach the site you gave. Could you upload it somewhere elese? |
Author: | demon [ Wed Oct 20, 2004 3:51 pm ] |
Post subject: | |
sure sorry for the delay "major server crash" one off my scsi'es went buum so had to reinstall everything ftp://83.90.155.229:21 login anonymous no pass if theres any trouble reaching my ftp please let me know so i can bug it out |
Author: | Jozsef [ Thu Oct 21, 2004 3:42 pm ] |
Post subject: | |
nope, it times out before i could connect |
Author: | demon [ Fri Nov 26, 2004 10:59 am ] |
Post subject: | |
ugh lost internet connection dunno if it will be back soon "trouble with my isp" Im writing from my old mans comp "not actually state off the art" yuck can try to mail it to you. Is about the only option i have atm "need to get it here on cd first though" Sorry for the late reply been moving |
Author: | Jozsef [ Fri Nov 26, 2004 4:41 pm ] |
Post subject: | |
no problem. Could you send the necessarry files to joe_quake@hotmail.com |
Page 1 of 1 | All times are UTC - 5 hours [ DST ] |
Powered by phpBB® Forum Software © phpBB Group https://www.phpbb.com/ |