/** Update the world and the track. * \param dt Time step size. */ void ThreeStrikesBattle::update(float dt) { WorldWithRank::update(dt); WorldWithRank::updateTrack(dt); core::vector3df tire_offset; std::string tire; float scale = 0.5f; float radius = 0.5f; PhysicalObject::bodyTypes tire_model; // insert blown away tire(s) now if was requested while (m_insert_tire > 0) { if(m_insert_tire == 1) { tire_offset = core::vector3df(0.0f, 0.0f, 0.0f); tire = file_manager->getModelFile("tire.b3d"); scale = 0.5f; radius = 0.5f; tire_model = PhysicalObject::MP_CYLINDER_Y; } else { scale = 1.0f; tire_model = PhysicalObject::MP_CYLINDER_X; radius = m_tire_radius[m_insert_tire-2]; tire_offset = m_tire_offsets[m_insert_tire-2]; if (m_insert_tire == 2) tire = m_tire_dir+"/wheel-rear-left.b3d"; else if(m_insert_tire == 3) tire = m_tire_dir+"/wheel-front-left.b3d"; else if(m_insert_tire == 4) tire = m_tire_dir+"/wheel-front-right.b3d"; else if(m_insert_tire == 5) tire = m_tire_dir+"/wheel-rear-right.b3d"; } TrackObjectManager* tom = m_track->getTrackObjectManager(); PhysicalObject* obj = tom->insertObject(tire, tire_model, 15 /* mass */, radius /* radius */, core::vector3df(800.0f,0,m_tire_rotation / M_PI * 180 + 180) , m_tire_position + tire_offset, core::vector3df(scale,scale,scale) /* scale */); // FIXME: orient the force relative to kart orientation obj->getBody()->applyCentralForce(btVector3(60.0f, 0.0f, 0.0f)); m_insert_tire--; if(m_insert_tire == 1) m_insert_tire = 0; m_tires.push_back(obj); } } // update
void GrandPrixWin::setKarts(const std::string idents_arg[3]) { TrackObjectManager* tobjman = Track::getCurrentTrack()->getTrackObjectManager(); // reorder in "podium order" (i.e. second player to the left, first player // in the middle, last at the right) std::string idents[3]; idents[0] = idents_arg[1]; idents[1] = idents_arg[0]; idents[2] = idents_arg[2]; for (int i = 0; i < 3; i++) { const KartProperties* kp = kart_properties_manager->getKart(idents[i]); if (kp == NULL) continue; KartModel* kart_model = kp->getKartModelCopy(KRT_DEFAULT); m_all_kart_models.push_back(kart_model); scene::ISceneNode* kart_main_node = kart_model->attachModel(false, false); m_kart_x[i] = KARTS_X + i*KARTS_DELTA_X; m_kart_y[i] = INITIAL_Y + KARTS_DELTA_Y; m_kart_z[i] = KARTS_INITIAL_Z; m_kart_rotation[i] = 0.0f; core::vector3df kart_pos(m_kart_x[i], m_kart_y[i], m_kart_z[i]); core::vector3df kart_rot(0, 0, 0); core::vector3df kart_scale(1.0f, 1.0f, 1.0f); //FIXME: it's not ideal that both the track object and the presentation // know the initial coordinates of the object TrackObjectPresentationSceneNode* presentation = new TrackObjectPresentationSceneNode(kart_pos, kart_rot, kart_scale, kart_main_node); TrackObject* tobj = new TrackObject(kart_pos, kart_rot, kart_scale, "ghost", presentation, false /* isDynamic */, NULL /* physics settings */); tobjman->insertObject(tobj); m_kart_node[i] = tobj; } TrackObject* currObj; PtrVector<TrackObject>& objects = tobjman->getObjects(); for_in(currObj, objects) { TrackObjectPresentationMesh* meshPresentation = currObj->getPresentation<TrackObjectPresentationMesh>(); if (meshPresentation != NULL) { if (meshPresentation->getModelFile() == "gpwin_podium1.b3d") m_podium_steps[0] = currObj; else if (meshPresentation->getModelFile() == "gpwin_podium2.b3d") m_podium_steps[1] = currObj; else if (meshPresentation->getModelFile() == "gpwin_podium3.b3d") m_podium_steps[2] = currObj; } }
void GrandPrixLose::setKarts(std::vector<std::string> ident_arg) { TrackObjectManager* tobjman = World::getWorld()->getTrack()->getTrackObjectManager(); assert(ident_arg.size() > 0); if ((int)ident_arg.size() > MAX_KART_COUNT) { ident_arg.resize(MAX_KART_COUNT); } // (there is at least one kart so kart node 0 is sure to be set) m_kart_node[1] = NULL; m_kart_node[2] = NULL; m_kart_node[3] = NULL; m_kart_x = KART_START_X; m_kart_y = KART_Y; m_kart_z = KART_Z; const int count = ident_arg.size(); for (int n=0; n<count; n++) { const KartProperties* kart = kart_properties_manager->getKart(ident_arg[n]); if (kart != NULL) { KartModel* kart_model = kart->getKartModelCopy(); m_all_kart_models.push_back(kart_model); scene::ISceneNode* kart_main_node = kart_model->attachModel(false, false); core::vector3df kart_pos(m_kart_x + n*DISTANCE_BETWEEN_KARTS, m_kart_y, m_kart_z); core::vector3df kart_rot(0, 90.0f, 0); core::vector3df kart_scale(KART_SCALE, KART_SCALE, KART_SCALE); //FIXME: it's not ideal that both the track object and the presentation know the initial coordinates of the object TrackObjectPresentationSceneNode* presentation = new TrackObjectPresentationSceneNode( kart_main_node, kart_pos, kart_rot, kart_scale); TrackObject* tobj = new TrackObject(kart_pos, kart_rot, kart_scale, "ghost", presentation, false /* isDynamic */, NULL /* physics settings */); tobjman->insertObject(tobj); m_kart_node[n] = tobj; } else { Log::warn("GrandPrixLose", "Could not find a kart named '%s'.", ident_arg[n].c_str()); m_kart_node[n] = NULL; } // if kart != NULL } } // setKarts
void GrandPrixWin::setKarts(const std::string idents_arg[3]) { TrackObjectManager* tobjman = Track::getCurrentTrack()->getTrackObjectManager(); // reorder in "podium order" (i.e. second player to the left, first player // in the middle, last at the right) std::string idents[3]; idents[0] = idents_arg[1]; idents[1] = idents_arg[0]; idents[2] = idents_arg[2]; for (int i = 0; i < 3; i++) { const KartProperties* kp = kart_properties_manager->getKart(idents[i]); if (kp == NULL) continue; KartModel* kart_model = kp->getKartModelCopy(); m_all_kart_models.push_back(kart_model); scene::ISceneNode* kart_main_node = kart_model->attachModel(true, false); LODNode* lnode = dynamic_cast<LODNode*>(kart_main_node); if (lnode) { // Lod node has to be animated auto* a_node = static_cast<scene::IAnimatedMeshSceneNode*> (lnode->getAllNodes()[0]); const unsigned start_frame = kart_model->getFrame(KartModel::AF_WIN_LOOP_START) > -1 ? kart_model->getFrame(KartModel::AF_WIN_LOOP_START) : kart_model->getFrame(KartModel::AF_WIN_START) > -1 ? kart_model->getFrame(KartModel::AF_WIN_START) : kart_model->getFrame(KartModel::AF_STRAIGHT); const unsigned end_frame = kart_model->getFrame(KartModel::AF_WIN_END) > -1 ? kart_model->getFrame(KartModel::AF_WIN_END) : kart_model->getFrame(KartModel::AF_STRAIGHT); a_node->setLoopMode(true); a_node->setFrameLoop(start_frame, end_frame); } m_kart_x[i] = KARTS_INITIAL_X[i]; m_kart_y[i] = KARTS_INITIAL_Y[i]; m_kart_z[i] = KARTS_INITIAL_Z[i]; m_kart_rotation[i] = KARTS_AND_PODIUMS_INITIAL_ROTATION[i]; core::vector3df kart_pos(m_kart_x[i], m_kart_y[i], m_kart_z[i]); core::vector3df kart_rot(0, 0, 0); core::vector3df kart_scale(1.0f, 1.0f, 1.0f); //FIXME: it's not ideal that both the track object and the presentation // know the initial coordinates of the object TrackObjectPresentationSceneNode* presentation = new TrackObjectPresentationSceneNode(kart_pos, kart_rot, kart_scale, kart_main_node); TrackObject* tobj = new TrackObject(kart_pos, kart_rot, kart_scale, "ghost", presentation, false /* isDynamic */, NULL /* physics settings */); tobjman->insertObject(tobj); m_kart_node[i] = tobj; } TrackObject* currObj; PtrVector<TrackObject>& objects = tobjman->getObjects(); for_in(currObj, objects) { TrackObjectPresentationMesh* meshPresentation = currObj->getPresentation<TrackObjectPresentationMesh>(); if (meshPresentation != NULL) { if (meshPresentation->getModelFile() == "gpwin_podium1.spm") m_podium_steps[0] = currObj; else if (meshPresentation->getModelFile() == "gpwin_podium2.spm") m_podium_steps[1] = currObj; else if (meshPresentation->getModelFile() == "gpwin_podium3.spm") m_podium_steps[2] = currObj; } }