diff options
| author | Markus Mittendrein <maxmitti@maxmitti.tk> | 2022-02-13 22:52:06 +0100 |
|---|---|---|
| committer | Markus Mittendrein <maxmitti@maxmitti.tk> | 2022-02-13 22:52:06 +0100 |
| commit | 35c071c3df89ea3b8b0a99d59892bcb8bff33f93 (patch) | |
| tree | 349923c957a49ce69db97cc23db9fafe027764ff /Targets.c4d/Knights.c4d/System.c4g/Script.c | |
| parent | d15afd40b3bf6de59beeaa98d7896b8c2ab7878c (diff) | |
| download | DTSensors.c4d-35c071c3df89ea3b8b0a99d59892bcb8bff33f93.tar.gz DTSensors.c4d-35c071c3df89ea3b8b0a99d59892bcb8bff33f93.zip | |
Enable Knights Targets with #appendto nowarn
Diffstat (limited to 'Targets.c4d/Knights.c4d/System.c4g/Script.c')
| -rw-r--r-- | Targets.c4d/Knights.c4d/System.c4g/Script.c | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/Targets.c4d/Knights.c4d/System.c4g/Script.c b/Targets.c4d/Knights.c4d/System.c4g/Script.c new file mode 100644 index 0000000..e9a8e69 --- /dev/null +++ b/Targets.c4d/Knights.c4d/System.c4g/Script.c @@ -0,0 +1,73 @@ +#strict 2 +#appendto CPT2 nowarn + +func IsRemoteControllable() { return false; } + +func FindGate(bool right) { return FindObject(0, 0, 0, 0, 0, 0, (right && "GateRight") || "GateLeft", this); } + +func SensorCallbacks() +{ + var ret = []; + for(var part in [[false, "$TWR2_LeftGate$", ["LeftGateOpen", "LeftGateClose", "ControlLeft"]], [true, "$TWR2_RightGate$", ["RightGateOpen", "RightGateClose", "ControlRight"]]]) + { + if(FindGate(part[0])) + { + ret[] = [Format("$TWR2_GateOpen$", part[1]), part[2][0]]; + ret[] = [Format("$TWR2_GateClose$", part[1]), part[2][1]]; + ret[] = [Format("$TWR2_GateOpenClose$", part[1]), part[2][2]]; + } + } + + if((GetID() == CPT3 || GetID() == CPT4) && this->FindDrawbridge()) + { + ret[] = ["$TWR2_DrawBridgeUp$", "ControlUp"]; + ret[] = ["$TWR2_DrawBridgeDown$", "ControlDownSingle"]; + ret[] = ["$TWR2_DrawBridgeUpDown$", "ToggleDrawBridge"]; + } + + return ret; +} + +func LeftGateOpen() { return GateOpen(false); } +func LeftGateClose() { return GateClose(false); } + +func RightGateOpen() { return GateOpen(true); } +func RightGateClose() { return GateClose(true); } + +func GateOpen(bool right) { return GateOpenClose(right, false); } +func GateClose(bool right) { return GateOpenClose(right, true); } + +func GateOpenClose(bool right, bool close) +{ + var gate = FindGate(right); + if(gate) + { + gate->Activate(); + + if(close) + { + gate->Close(); + } + else + { + gate->Open(); + } + } +} + +func ToggleDrawBridge() +{ + var bridge = this->FindDrawbridge(); + if(bridge) + { + if(bridge->IsUp()) + { + return bridge->ControlDown(); + } + else + { + return bridge->ControlUp(); + } + } +} + |
