Revision: 2516 http://rigsofrods.svn.sourceforge.net/rigsofrods/?rev=2516&view=rev Author: ulteq Date: 2012-05-06 07:06:55 +0000 (Sun, 06 May 2012) Log Message: ----------- -Feature: re-enabled createCollisionDebugVisualization(), style++
Modified Paths: -------------- trunk/source/main/physics/collision/collisions.cpp Modified: trunk/source/main/physics/collision/collisions.cpp =================================================================== --- trunk/source/main/physics/collision/collisions.cpp 2012-05-06 07:02:55 UTC (rev 2515) +++ trunk/source/main/physics/collision/collisions.cpp 2012-05-06 07:06:55 UTC (rev 2516) @@ -511,10 +511,13 @@ Ogre::Vector3 p(px, py, pz); Ogre::Vector3 sc(scx, scy, scz); collision_box_t& coll_box = collision_boxes[free_collision_box]; + coll_box.enabled = true; + // set refined box anyway coll_box.relo = l*sc; coll_box.rehi = h*sc; + // calculate selfcenter anyway coll_box.selfcenter = coll_box.relo; coll_box.selfcenter += coll_box.rehi; @@ -523,8 +526,8 @@ // and center too (we need it) coll_box.center = p; coll_box.virt = virt; + coll_box.event_filter = event_filter; - coll_box.event_filter = event_filter; // camera stuff coll_box.camforced = forcecam; if (forcecam) @@ -539,10 +542,13 @@ coll_box.selfrotated = true; coll_box.selfrot = Quaternion(Degree(srx), Vector3::UNIT_X)*Quaternion(Degree(sry), Vector3::UNIT_Y)*Quaternion(Degree(srz), Vector3::UNIT_Z); coll_box.selfunrot = coll_box.selfrot.Inverse(); + } else + { + coll_box.selfrotated = false; } - else coll_box.selfrotated = false; coll_box.eventsourcenum = -1; + if (strlen(eventname) > 0) { //LOG("COLL: adding "+TOSTRING(free_eventsource)+" "+String(instancename)+" "+String(eventname)); @@ -572,7 +578,12 @@ coll_box.unrot = rotation.Inverse(); } - SceneNode *debugsn = debugMode ? smgr->getRootSceneNode()->createChildSceneNode() : 0; + SceneNode *debugsn = 0; + + if (debugMode) + { + debugsn = smgr->getRootSceneNode()->createChildSceneNode(); + } // set raw box // 8 points of a cube @@ -1103,7 +1114,6 @@ if (ogm) *ogm=defaultgm; } } - } else { if (cbox->eventsourcenum!=-1 && permitEvent(cbox->event_filter)) @@ -1145,8 +1155,7 @@ } } } - } - else + } else { // tri collision collision_tri_t *ctri=&collision_tris[(*cell)[k]-MAX_COLLISION_BOXES]; @@ -1250,7 +1259,7 @@ eventsource_t *Collisions::isTruckInEventBox(Beam *truck) { - if(!truck) return 0; + if (!truck) return 0; // check all boxes for (int i=0; i<free_eventsource; i++) { @@ -1282,7 +1291,6 @@ bool Collisions::isInside(Vector3 pos, char* instance, char* box, float border) { - collision_box_t *cbox=getBox(instance, box); return isInside(pos, cbox, border); } @@ -1292,28 +1300,33 @@ if (!cbox) return false; if (pos + border > cbox->lo - && pos - border < cbox->hi) + && pos - border < cbox->hi) { if (cbox->refined || cbox->selfrotated) { // we may have a collision, do a change of repere - Vector3 rpos=pos-cbox->center; - if (cbox->refined) rpos=cbox->unrot*rpos; + Vector3 rpos = pos - cbox->center; + if (cbox->refined) + { + rpos = cbox->unrot * rpos; + } if (cbox->selfrotated) { - rpos=rpos-cbox->selfcenter; - rpos=cbox->selfunrot*rpos; - rpos=rpos+cbox->selfcenter; + rpos = rpos - cbox->selfcenter; + rpos = cbox->selfunrot * rpos; + rpos = rpos + cbox->selfcenter; } // now test with the inner box - if (rpos >cbox->relo - && rpos < cbox->rehi) + if (rpos > cbox->relo + && rpos < cbox->rehi) { return true; } + } else + { + return true; } - else return true; } return false; } @@ -1321,9 +1334,9 @@ bool Collisions::groundCollision(node_t *node, float dt, ground_model_t** ogm, float *nso) { if (!hfinder) return false; - if(landuse) *ogm = landuse->getGroundModelAt(node->AbsPosition.x, node->AbsPosition.z); + if (landuse) *ogm = landuse->getGroundModelAt(node->AbsPosition.x, node->AbsPosition.z); // when landuse fails or we dont have it, use the default value - if(!*ogm) *ogm = defaultgroundgm; + if (!*ogm) *ogm = defaultgroundgm; last_used_ground_model = *ogm; // new ground collision code @@ -1452,7 +1465,8 @@ int Collisions::createCollisionDebugVisualization() { - return 0; + LOG("COLL: Creating collision debug visualization ..."); + static int loaded = 0; // prevent double calling if (loaded != 0) return -1; @@ -1518,7 +1532,8 @@ groundheight+=0.1; // 10 cm hover // ground height should fit - int deep = 0, cc=(int)cell->size(); + //int deep = 0; + int cc = (int)cell->size(); float percent = cc / (float)CELL_BLOCKSIZE; float percentd = percent; @@ -1555,7 +1570,6 @@ mo->setBoundingBox(AxisAlignedBox(0, 0, 0, CELL_SIZE, 1, CELL_SIZE)); mo_node->attachObject(mo); - #if 0 // setup the label String labelName = "label_"+cell_name; @@ -1647,8 +1661,8 @@ size_t shared_offset = vertex_count; size_t next_offset = vertex_count; size_t index_offset = index_count; - size_t prev_vert = vertex_count; - size_t prev_ind = index_count; + //size_t prev_vert = vertex_count; + //size_t prev_ind = index_count; // Calculate how many vertices and indices we're going to need for(int i = 0;i < mesh->getNumSubMeshes();i++) This was sent by the SourceForge.net collaborative development platform, the world's largest Open Source development site. ------------------------------------------------------------------------------ Live Security Virtual Conference Exclusive live event will cover all the ways today's security and threat landscape has changed and how IT managers can respond. Discussions will include endpoint security, mobile security and the latest in malware threats. http://www.accelacomm.com/jaw/sfrnl04242012/114/50122263/ _______________________________________________ Rigsofrods-devel mailing list Rigsofrods-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/rigsofrods-devel