rust/hwphysics/src/physics.rs
author Wuzzy <Wuzzy2@mail.ru>
Mon, 07 Oct 2019 14:18:31 +0200
changeset 15447 6031c0cfec89
parent 15398 0ef770a40e75
permissions -rw-r--r--
Make sure AI doesn't skip after collecting ammo. Fixes bug #796
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
15385
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
     1
use crate::{
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
     2
    common::{GearId, Millis},
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
     3
    data::GearDataManager,
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
     4
};
15125
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
     5
use fpnum::*;
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
     6
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
     7
#[derive(PartialEq, Eq, Clone, Copy, Debug)]
15385
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
     8
#[repr(transparent)]
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
     9
pub struct PositionData(pub FPPoint);
15125
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    10
15385
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
    11
#[derive(PartialEq, Eq, Clone, Copy, Debug)]
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
    12
#[repr(transparent)]
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
    13
pub struct VelocityData(pub FPPoint);
15125
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    14
15398
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    15
pub struct AffectedByWind;
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    16
15125
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    17
pub struct PositionUpdates {
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    18
    pub gear_ids: Vec<GearId>,
15265
775d7efa4e5c save full shifts to position updates
alfadur
parents: 15125
diff changeset
    19
    pub shifts: Vec<(FPPoint, FPPoint)>,
15125
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    20
}
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    21
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    22
impl PositionUpdates {
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    23
    pub fn new(capacity: usize) -> Self {
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    24
        Self {
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    25
            gear_ids: Vec::with_capacity(capacity),
15265
775d7efa4e5c save full shifts to position updates
alfadur
parents: 15125
diff changeset
    26
            shifts: Vec::with_capacity(capacity),
15125
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    27
        }
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    28
    }
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    29
15265
775d7efa4e5c save full shifts to position updates
alfadur
parents: 15125
diff changeset
    30
    pub fn push(&mut self, gear_id: GearId, old_position: &FPPoint, new_position: &FPPoint) {
15125
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    31
        self.gear_ids.push(gear_id);
15265
775d7efa4e5c save full shifts to position updates
alfadur
parents: 15125
diff changeset
    32
        self.shifts.push((*old_position, *new_position));
15125
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    33
    }
15266
501dfa1c8deb update collision grid with position changes
alfadur
parents: 15265
diff changeset
    34
501dfa1c8deb update collision grid with position changes
alfadur
parents: 15265
diff changeset
    35
    pub fn iter(&self) -> impl Iterator<Item = (GearId, &FPPoint, &FPPoint)> {
501dfa1c8deb update collision grid with position changes
alfadur
parents: 15265
diff changeset
    36
        self.gear_ids
501dfa1c8deb update collision grid with position changes
alfadur
parents: 15265
diff changeset
    37
            .iter()
501dfa1c8deb update collision grid with position changes
alfadur
parents: 15265
diff changeset
    38
            .cloned()
501dfa1c8deb update collision grid with position changes
alfadur
parents: 15265
diff changeset
    39
            .zip(self.shifts.iter())
501dfa1c8deb update collision grid with position changes
alfadur
parents: 15265
diff changeset
    40
            .map(|(id, (from, to))| (id, from, to))
501dfa1c8deb update collision grid with position changes
alfadur
parents: 15265
diff changeset
    41
    }
15271
b58f98bbc120 clear intermediate result structures between iterations
alfadur
parents: 15266
diff changeset
    42
b58f98bbc120 clear intermediate result structures between iterations
alfadur
parents: 15266
diff changeset
    43
    pub fn clear(&mut self) {
b58f98bbc120 clear intermediate result structures between iterations
alfadur
parents: 15266
diff changeset
    44
        self.gear_ids.clear();
b58f98bbc120 clear intermediate result structures between iterations
alfadur
parents: 15266
diff changeset
    45
        self.shifts.clear();
b58f98bbc120 clear intermediate result structures between iterations
alfadur
parents: 15266
diff changeset
    46
    }
15125
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    47
}
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    48
15386
52844baced17 add gravity
alfadur
parents: 15385
diff changeset
    49
pub struct PhysicsProcessor {
52844baced17 add gravity
alfadur
parents: 15385
diff changeset
    50
    gravity: FPNum,
15398
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    51
    wind: FPNum,
15386
52844baced17 add gravity
alfadur
parents: 15385
diff changeset
    52
    position_updates: PositionUpdates,
52844baced17 add gravity
alfadur
parents: 15385
diff changeset
    53
}
52844baced17 add gravity
alfadur
parents: 15385
diff changeset
    54
15125
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    55
impl PhysicsProcessor {
15385
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
    56
    pub fn register_components(data: &mut GearDataManager) {
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
    57
        data.register::<PositionData>();
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
    58
        data.register::<VelocityData>();
15398
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    59
        data.register::<AffectedByWind>();
15385
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
    60
    }
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
    61
15125
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    62
    pub fn new() -> Self {
15275
7446258fab98 add time events
alfadur
parents: 15271
diff changeset
    63
        Self {
15388
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    64
            gravity: fp!(1 / 10),
15398
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    65
            wind: fp!(0),
15385
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
    66
            position_updates: PositionUpdates::new(64),
15125
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    67
        }
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    68
    }
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
    69
15388
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    70
    pub fn process_single_tick(&mut self, data: &mut GearDataManager) -> &PositionUpdates {
15398
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    71
        let gravity = FPPoint::unit_y() * self.gravity;
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    72
        let wind = FPPoint::unit_x() * self.wind;
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    73
15388
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    74
        self.position_updates.clear();
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    75
15398
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    76
        data.iter()
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    77
            .with_tags::<&AffectedByWind>()
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    78
            .run(|(vel,): (&mut VelocityData,)| {
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    79
                vel.0 += wind;
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    80
            });
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    81
15397
b387a51705ac implement iteration with tags
alfadur
parents: 15388
diff changeset
    82
        data.iter().run_id(
15388
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    83
            |gear_id, (pos, vel): (&mut PositionData, &mut VelocityData)| {
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    84
                let old_pos = pos.0;
15398
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
    85
                vel.0 += gravity;
15388
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    86
                pos.0 += vel.0;
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    87
                self.position_updates.push(gear_id, &old_pos, &pos.0)
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    88
            },
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    89
        );
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    90
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    91
        &self.position_updates
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    92
    }
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    93
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    94
    pub fn process_multiple_ticks(
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    95
        &mut self,
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    96
        data: &mut GearDataManager,
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    97
        time_step: Millis,
701ad89a9f2a avoid time multiplication when not skipping ticks
alfadur
parents: 15387
diff changeset
    98
    ) -> &PositionUpdates {
15280
66c987015f2d replace time with milliseconds
alfadur
parents: 15279
diff changeset
    99
        let fp_step = time_step.to_fixed();
15398
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
   100
        let gravity = FPPoint::unit_y() * (self.gravity * fp_step);
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
   101
        let wind = FPPoint::unit_x() * (self.wind * fp_step);
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
   102
15271
b58f98bbc120 clear intermediate result structures between iterations
alfadur
parents: 15266
diff changeset
   103
        self.position_updates.clear();
15385
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
   104
15398
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
   105
        data.iter()
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
   106
            .with_tags::<&AffectedByWind>()
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
   107
            .run(|(vel,): (&mut VelocityData,)| {
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
   108
                vel.0 += wind;
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
   109
            });
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
   110
15397
b387a51705ac implement iteration with tags
alfadur
parents: 15388
diff changeset
   111
        data.iter().run_id(
15385
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
   112
            |gear_id, (pos, vel): (&mut PositionData, &mut VelocityData)| {
15387
6ad92b6ac43c remove velocity check
alfadur
parents: 15386
diff changeset
   113
                let old_pos = pos.0;
15398
0ef770a40e75 add wind to physics processor
alfadur
parents: 15397
diff changeset
   114
                vel.0 += gravity;
15387
6ad92b6ac43c remove velocity check
alfadur
parents: 15386
diff changeset
   115
                pos.0 += vel.0 * fp_step;
6ad92b6ac43c remove velocity check
alfadur
parents: 15386
diff changeset
   116
                self.position_updates.push(gear_id, &old_pos, &pos.0)
15385
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
   117
            },
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
   118
        );
6e3e5be8b2e2 update hwphysics motion to use the new system
alfadur
parents: 15287
diff changeset
   119
15125
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
   120
        &self.position_updates
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
   121
    }
febccab419b1 Apply dos2unix to rust sources
unc0rr
parents: 14721
diff changeset
   122
}