Revision: 2613
          http://rigsofrods.svn.sourceforge.net/rigsofrods/?rev=2613&view=rev
Author:   ulteq
Date:     2012-05-20 18:48:17 +0000 (Sun, 20 May 2012)
Log Message:
-----------
-Feature: merged theshark's speedlimiter patch - thanks
+cruise control target speed now limited by the trucks speed limit
+cruise control target rpm now limited by Idle- and Max-RPM

Modified Paths:
--------------
    trunk/source/main/gameplay/RoRFrameListener.cpp
    trunk/source/main/physics/Beam.cpp
    trunk/source/main/physics/BeamData.h
    trunk/source/main/physics/input_output/SerializedRig.cpp

Modified: trunk/source/main/gameplay/RoRFrameListener.cpp
===================================================================
--- trunk/source/main/gameplay/RoRFrameListener.cpp     2012-05-20 15:41:04 UTC 
(rev 2612)
+++ trunk/source/main/gameplay/RoRFrameListener.cpp     2012-05-20 18:48:17 UTC 
(rev 2613)
@@ -1850,9 +1850,11 @@
 
 void updateCruiseControl(Beam* curr_truck, float dt)
 {
-       if (INPUTENGINE.getEventValue(EV_TRUCK_BRAKE) > 0.05 || 
INPUTENGINE.getEventValue(EV_TRUCK_MANUAL_CLUTCH) > 0.05
-               || (curr_truck->parkingbrake && curr_truck->engine->getGear() > 
0)
-               || !curr_truck->engine->running || !curr_truck->engine->contact)
+       if (INPUTENGINE.getEventValue(EV_TRUCK_BRAKE) > 0.05f ||
+               INPUTENGINE.getEventValue(EV_TRUCK_MANUAL_CLUTCH) > 0.05f ||
+               (curr_truck->parkingbrake && curr_truck->engine->getGear() > 0) 
||
+               !curr_truck->engine->running ||
+               !curr_truck->engine->contact)
        {
                curr_truck->cruisecontrolToggle();
                return;
@@ -1863,9 +1865,9 @@
                // Try to maintain the target speed
                if (curr_truck->cc_target_speed > curr_truck->WheelSpeed)
                {
-                       float accl = (curr_truck->cc_target_speed - 
curr_truck->WheelSpeed);
+                       float accl = (curr_truck->cc_target_speed - 
curr_truck->WheelSpeed) * 2.0f;
+                       accl = std::max(curr_truck->engine->getAcc(), accl);
                        accl = std::min(accl, 1.0f);
-                       accl = 
std::max(INPUTENGINE.getEventValue(EV_TRUCK_ACCELERATE), accl);
                        curr_truck->engine->setAcc(accl);
                }
        } else if (curr_truck->engine->getGear() == 0) // out of gear
@@ -1873,9 +1875,9 @@
                // Try to maintain the target rpm
                if (curr_truck->cc_target_rpm > curr_truck->engine->getRPM())
                {
-                       float accl = (curr_truck->cc_target_rpm - 
curr_truck->engine->getRPM()) * 0.01;
+                       float accl = (curr_truck->cc_target_rpm - 
curr_truck->engine->getRPM()) * 0.01f;
+                       accl = std::max(curr_truck->engine->getAcc(), accl);
                        accl = std::min(accl, 1.0f);
-                       accl = 
std::max(INPUTENGINE.getEventValue(EV_TRUCK_ACCELERATE), accl);
                        curr_truck->engine->setAcc(accl);
                }
        }
@@ -1884,38 +1886,54 @@
        {
                if (curr_truck->engine->getGear() > 0)
                {
-                       curr_truck->cc_target_speed += 5 * dt;
+                       curr_truck->cc_target_speed += 5.0f * dt;
+                       curr_truck->cc_target_speed  = std::max(0.0f, 
curr_truck->cc_target_speed);
+                       curr_truck->cc_target_speed  = 
std::min(curr_truck->cc_target_speed, curr_truck->sl_speed_limit);
                } else if (curr_truck->engine->getGear() == 0) // out of gear
                {
                        curr_truck->cc_target_rpm += 1000.0f * dt;
+                       curr_truck->cc_target_rpm  = 
std::min(curr_truck->cc_target_rpm, curr_truck->engine->getMaxRPM());
                }
        }
        if (INPUTENGINE.getEventBoolValue(EV_TRUCK_CRUISE_CONTROL_DECL))
        {
                if (curr_truck->engine->getGear() > 0)
                {
-                       curr_truck->cc_target_speed -= 5 * dt;
+                       curr_truck->cc_target_speed -= 5.0f * dt;
+                       curr_truck->cc_target_speed  = std::max(0.0f, 
curr_truck->cc_target_speed);
                } else if (curr_truck->engine->getGear() == 0) // out of gear
                {
                        curr_truck->cc_target_rpm -= 1000.0f * dt;
+                       curr_truck->cc_target_rpm  = 
std::max(curr_truck->engine->getIdleRPM(), curr_truck->cc_target_rpm);
                }
        }
        if (INPUTENGINE.getEventBoolValue(EV_TRUCK_CRUISE_CONTROL_READJUST))
        {
-               curr_truck->cc_target_speed = curr_truck->WheelSpeed;
+               curr_truck->cc_target_speed = std::min(curr_truck->WheelSpeed, 
curr_truck->sl_speed_limit);
                curr_truck->cc_target_rpm   = curr_truck->engine->getRPM();
        }
 
 #if 0
        if (curr_truck->WheelSpeed > curr_truck->cc_target_speed + 0.5f && 
!INPUTENGINE.getEventValue(EV_TRUCK_ACCELERATE))
        {
-               float brake = (curr_truck->WheelSpeed - 
curr_truck->cc_target_speed) * 0.5;
+               float brake = (curr_truck->WheelSpeed - 
curr_truck->cc_target_speed) * 0.5f;
                brake = std::min(brake, 1.0f);
                curr_truck->brake = curr_truck->brakeforce * brake;
        }
 #endif
 }
 
+void checkSpeedlimit(Beam* curr_truck, float dt)
+{
+       if (curr_truck->engine->getGear() > 0)
+       {
+               float accl = (curr_truck->sl_speed_limit - 
curr_truck->WheelSpeed) * 2.0f;
+               accl = std::max(0.0f, accl);
+               accl = std::min(accl, curr_truck->engine->getAcc());
+               curr_truck->engine->setAcc(accl);
+       }
+}
+
 bool RoRFrameListener::updateEvents(float dt)
 {
        if (dt==0.0f) return true;
@@ -2108,14 +2126,14 @@
        }
 
        // camera FOV settings
-       if (INPUTENGINE.getEventBoolValueBounce(EV_COMMON_FOV_LESS) || 
INPUTENGINE.getEventBoolValueBounce(EV_COMMON_FOV_MORE))
+       if (INPUTENGINE.getEventBoolValueBounce(EV_COMMON_FOV_LESS, 0.1f) || 
INPUTENGINE.getEventBoolValueBounce(EV_COMMON_FOV_MORE, 0.1f))
        {
                int fov = mCamera->getFOVy().valueDegrees();
 
                if (INPUTENGINE.getEventBoolValue(EV_COMMON_FOV_LESS))
-                       fov -= 2;
+                       fov--;
                else
-                       fov += 2;
+                       fov++;
 
                if (fov >= 10 && fov <= 160)
                {
@@ -2698,7 +2716,7 @@
 
                                                
updateCruiseControl(curr_truck,dt);
                                        }
-                                       
+                                       checkSpeedlimit(curr_truck, dt);
                                }
                                if (curr_truck->driveable==AIRPLANE)
                                {

Modified: trunk/source/main/physics/Beam.cpp
===================================================================
--- trunk/source/main/physics/Beam.cpp  2012-05-20 15:41:04 UTC (rev 2612)
+++ trunk/source/main/physics/Beam.cpp  2012-05-20 18:48:17 UTC (rev 2613)
@@ -200,9 +200,9 @@
        cablight = 0;
        cablightNode = 0;
 
-       cc_mode = 0;
-       cc_target_rpm = 0;
-       cc_target_speed = 0;
+       cc_mode = false;
+       cc_target_rpm = 0.0f;
+       cc_target_speed = 0.0f;
 
        debugVisuals = 0;
 
@@ -256,7 +256,10 @@
 
        previousCrank = 0.0f;
 
+       sl_speed_limit = std::numeric_limits<float>::max();
+
        state = SLEEPING;
+
        tc_fade = 0.0f;
        tc_mode = 0;
        tc_present = false;

Modified: trunk/source/main/physics/BeamData.h
===================================================================
--- trunk/source/main/physics/BeamData.h        2012-05-20 15:41:04 UTC (rev 
2612)
+++ trunk/source/main/physics/BeamData.h        2012-05-20 18:48:17 UTC (rev 
2613)
@@ -892,10 +892,13 @@
        float animTimer;
 
        // Cruise Control
-       int cc_mode;
+       bool cc_mode;
        float cc_target_rpm;
        float cc_target_speed;
 
+       // Speed Limiter
+       float sl_speed_limit;
+
        float beam_creak;
        char uniquetruckid[256];
        int categoryid;

Modified: trunk/source/main/physics/input_output/SerializedRig.cpp
===================================================================
--- trunk/source/main/physics/input_output/SerializedRig.cpp    2012-05-20 
15:41:04 UTC (rev 2612)
+++ trunk/source/main/physics/input_output/SerializedRig.cpp    2012-05-20 
18:48:17 UTC (rev 2613)
@@ -843,7 +843,7 @@
 
                                                } else
                                                {
-                                                       
parser_warning(c,"TractionControl Mode: missing " + String(fname) +" line " + 
StringConverter::toString(c.linecounter) + ". TractionControl Mode = ON.", 
PARSER_ERROR);
+                                                       parser_warning(c, 
"TractionControl Mode: missing " + String(fname) +" line " + 
StringConverter::toString(c.linecounter) + ". TractionControl Mode = ON.", 
PARSER_ERROR);
                                                        tc_present = true;
                                                        tc_mode = 1;
                                                }
@@ -851,6 +851,17 @@
                                }
                                continue;
                        }
+                       if (c.line.size() > 12 && c.line.substr(0, 12) == 
"speedlimiter")
+                       {
+                               parse_args(c, args, 2);
+                               sl_speed_limit = PARSEREAL(args[1]);
+                               if (sl_speed_limit <= 0.0f)
+                               {
+                                       parser_warning(c, "SpeedLimiter: 
Parameter must be a decimal and greater than zero (e.g. 69.445)");
+                                       continue;
+                               }
+                               continue;
+                       }
                        if (c.line.size() > 17 && c.line.substr(0, 17) == 
"fileformatversion")
                        {
                                parse_args(c, args, 2);

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

Reply via email to