Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add - Iron dome for defending against projectiles #10038

Open
wants to merge 287 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 250 commits
Commits
Show all changes
287 commits
Select commit Hold shift + click to select a range
e9d474c
remove placeholder
TheCandianVendingMachine Apr 13, 2021
e1436d6
Change out missile types to reflect navigation scheme they use IRL
TheCandianVendingMachine Apr 13, 2021
d34201e
remove uneeded sets
TheCandianVendingMachine Apr 13, 2021
a2d2dd0
chane navigation profiles to go for attack direction instead of target
TheCandianVendingMachine Apr 14, 2021
af2b9a2
multiple changes
TheCandianVendingMachine Apr 14, 2021
555f0c8
SALH: only update seeker pos if it within small error
TheCandianVendingMachine Apr 14, 2021
e2c8ddf
IR seeker and AIM-9M
TheCandianVendingMachine Apr 14, 2021
c714fb5
small tweaks
TheCandianVendingMachine Apr 14, 2021
fe2fedd
more tweaks
TheCandianVendingMachine Apr 14, 2021
8d52a2e
todo: fix nlaw
TheCandianVendingMachine Apr 14, 2021
a485399
update todo
TheCandianVendingMachine Apr 14, 2021
d077528
implement course state machine
TheCandianVendingMachine Apr 14, 2021
8318b60
Improve radar simulation
TheCandianVendingMachine Apr 16, 2021
26dee9f
enable chaff decoy
TheCandianVendingMachine Apr 16, 2021
0848d74
add config entries
TheCandianVendingMachine Apr 16, 2021
abc5bab
Implement optical mavericks
TheCandianVendingMachine Apr 16, 2021
1b000d6
Allow for debug info to be displayed via variable
TheCandianVendingMachine Apr 16, 2021
8f03b5b
Change AIM-9 agility
TheCandianVendingMachine Apr 16, 2021
fe1e6d4
update dragon to not use new guidance
TheCandianVendingMachine Apr 17, 2021
265670c
Tweak flight parameters. Add R-77
TheCandianVendingMachine Apr 17, 2021
8b88142
Add AIM-120A
TheCandianVendingMachine Apr 17, 2021
d622e4d
add ASRAAM
TheCandianVendingMachine Apr 17, 2021
f942231
add R-73/4
TheCandianVendingMachine Apr 17, 2021
e7919da
Add all GBU-12s that exist for all planes
TheCandianVendingMachine Apr 17, 2021
23cd1ef
update todo
TheCandianVendingMachine Apr 17, 2021
b18508b
update todo for ground based weapons
TheCandianVendingMachine Apr 17, 2021
e1cdbb7
Add GPS selector dialog for GPS munitions
TheCandianVendingMachine Apr 18, 2021
3878c67
add TOO TGP
TheCandianVendingMachine Apr 19, 2021
44b7b87
Add SDB and JDAM
TheCandianVendingMachine Apr 19, 2021
1cb8408
update todo
TheCandianVendingMachine Apr 19, 2021
12bcb95
fix gimbal lock via rotating with quaternions
TheCandianVendingMachine Apr 20, 2021
438cb8b
tweak JDAM guidance
TheCandianVendingMachine Apr 20, 2021
aea24c6
Better attack angle calculation. Does not get exactly right, but work…
TheCandianVendingMachine Apr 20, 2021
9d26335
Fix SACLOS missiles
TheCandianVendingMachine Apr 21, 2021
19dcf00
Fix NLAW and PLOS
TheCandianVendingMachine Apr 21, 2021
afbb1f6
update todo
TheCandianVendingMachine Apr 21, 2021
ba2eb48
update todo
TheCandianVendingMachine Apr 21, 2021
6b3be24
Add Vikhr ATGM
TheCandianVendingMachine Apr 21, 2021
a91b3aa
Add long range SAMs
TheCandianVendingMachine Apr 21, 2021
cba9dcd
fix SAM animations
TheCandianVendingMachine Apr 21, 2021
675b07d
Add all ground based missiles. Tweak AIM-9 flare angle
TheCandianVendingMachine Apr 21, 2021
a057768
remove debugh print
TheCandianVendingMachine Apr 21, 2021
7398033
Fix Wiesel ATGM animation. Tweak SACLOS values
TheCandianVendingMachine Apr 21, 2021
6cfc075
Add action to get into jdam settings
TheCandianVendingMachine Apr 21, 2021
73b0598
fix all script components
TheCandianVendingMachine Apr 21, 2021
f5b3161
Add paremter to allow weathervaning
TheCandianVendingMachine May 2, 2021
197c1a7
Add new navigation profile. Tweak javelin mid-course guidance
TheCandianVendingMachine May 2, 2021
de05c68
Process all navigation onFired. Send the correct array to function
TheCandianVendingMachine May 2, 2021
edc8250
fix missing semicolons
TheCandianVendingMachine May 2, 2021
b4e5a29
Add hellfire mid course guidance
TheCandianVendingMachine May 2, 2021
356ff4c
Tweak hellfire attack profile
TheCandianVendingMachine May 2, 2021
f3bea7b
change how IR seeker performs
TheCandianVendingMachine May 2, 2021
89e64df
tabs -> spaces
TheCandianVendingMachine May 2, 2021
79bd76a
localise aim120
TheCandianVendingMachine May 2, 2021
f12e934
localise aim9
TheCandianVendingMachine May 2, 2021
988768a
localise gbu
TheCandianVendingMachine May 2, 2021
c0e623a
fix IR tracker losing lock immediately due to being blocked by launcher
TheCandianVendingMachine May 2, 2021
c67bc4d
localise manpad
TheCandianVendingMachine May 2, 2021
5edabba
actually localise manpad
TheCandianVendingMachine May 2, 2021
0d38505
localise maverick
TheCandianVendingMachine May 2, 2021
f45ee87
localise missile guidance
TheCandianVendingMachine May 2, 2021
0a28e3e
localise sam
TheCandianVendingMachine May 2, 2021
72297be
localise sdb
TheCandianVendingMachine May 2, 2021
7988469
localise vikhr
TheCandianVendingMachine May 2, 2021
80b2595
tabs -> spaces again
TheCandianVendingMachine May 2, 2021
20a3277
init commit 9m14
TheCandianVendingMachine May 6, 2021
d8fb608
update stringtables so they are in titlecase
TheCandianVendingMachine May 7, 2021
a0e193a
crash on load
TheCandianVendingMachine May 7, 2021
e76fde4
perplexed
TheCandianVendingMachine May 7, 2021
f4f3224
fix game crashing on load
TheCandianVendingMachine May 7, 2021
8b3e909
Add joystick model
TheCandianVendingMachine May 7, 2021
fc7b310
Add realistic 9m14 behaviour
TheCandianVendingMachine May 8, 2021
5315b11
add MCLOS guidance
TheCandianVendingMachine May 8, 2021
1756524
add the ability to see a light trail
TheCandianVendingMachine May 8, 2021
ef529d2
tweak HOT guidance params
TheCandianVendingMachine May 8, 2021
c71be65
tweak metis guidance params
TheCandianVendingMachine May 8, 2021
6165be0
tweak Vikhr guidance
TheCandianVendingMachine May 8, 2021
b82484b
add trail to vikhr
TheCandianVendingMachine May 8, 2021
980c3d0
Add Iron Dome interceptor API
TheCandianVendingMachine May 18, 2021
a25cf70
Optimise iron dome
TheCandianVendingMachine May 18, 2021
f825d6f
Only launch if we are above a threshold angle
TheCandianVendingMachine May 18, 2021
72ca725
add local event for mission makers
TheCandianVendingMachine May 18, 2021
e67aefc
change events to allow for any number of arguments
TheCandianVendingMachine May 18, 2021
36d7576
avoid making un-needed calls to the server
TheCandianVendingMachine May 18, 2021
f7bd523
Update doppler seeker to allow the tracking and killing of projectiles
TheCandianVendingMachine May 18, 2021
395b2b2
Avoid overshooting target
TheCandianVendingMachine May 18, 2021
790faf1
Add settings for various things
TheCandianVendingMachine May 19, 2021
22e5596
Add missile hiding for malyutka
TheCandianVendingMachine May 21, 2021
2694453
init commit of cruise missile
TheCandianVendingMachine May 23, 2021
c5972e6
Various - Add missing units/weapons to cfgPatches (#8175)
PabstMirror Mar 17, 2021
dd5bd46
Documentation - Add Mikero binarization note (#8172)
jonpas Mar 17, 2021
fac35d5
Bump is-svg from 4.2.1 to 4.3.1 in /docs/src (#8177)
dependabot[bot] Mar 20, 2021
d9261c4
Adjust "New issue" link to lead to template selection page (#8182)
bux Mar 24, 2021
a5d7a00
Update linguist settings (#8151)
veteran29 Apr 8, 2021
44ecfc8
Typo in usage example (#8201)
t-zilla Apr 8, 2021
4e3d3ce
Mk6 Mortar - Fix README.md typo (#8205)
jonpas Apr 9, 2021
560a1da
Overhaul CSW docs (#8206)
BaerMitUmlaut Apr 12, 2021
b181f1b
Medical - Add Alternative Survival Chance (#8192)
Apr 15, 2021
fdc3ab0
Fix make.py temp files cleanup (#8189)
Dystopian Apr 17, 2021
9d6843f
Fix Injured Sounds Not Playing At Altitudes Above 70 (#8212)
commy2 Apr 17, 2021
090aa5d
Particles - Fix macro (#8214)
Mike-MF Apr 19, 2021
517b576
Map - Fix stuck map compass size (add 0.1 zoom duration) (#8176)
R3voA3 Apr 20, 2021
fa870a3
Medical - Allow unconscious unit in Taru pods (#8168)
ampersand38 Apr 20, 2021
7c87997
Name Tags - Add ability to set custom rank icon (#8174)
Drift91 Apr 20, 2021
3b9f374
Tools - Add script to update HEMTT include folder (#8134)
PabstMirror Apr 20, 2021
e3a3e29
Tools - Add script to check sqf/config with sqfvm (#8137)
PabstMirror Apr 20, 2021
c7d4981
Medical - Add Vehicle Crashes setting (#8149)
LinkIsGrim Apr 20, 2021
026b949
Dragging - Add new dragging animations (#7950)
Malbryn Apr 20, 2021
d41c5bd
Dragging - Fix build issue (#8219)
Mike-MF Apr 20, 2021
011389c
Documentation - Remove DeTex requirement (#8220)
jonpas Apr 20, 2021
89fb57f
User Interface - Add setting for Development Build watermark (#8140)
Dystopian Apr 20, 2021
4678518
RHS USAF Compat - Nightforce NXS scopes updated (#8222)
Laid3acK Apr 21, 2021
a80a0b8
Interact Menu - Make List default (#8217)
jonpas Apr 21, 2021
f1338e6
Markers - Add scale slider (#8059)
frankplow Apr 21, 2021
d8bdde0
Initial push (#8225)
JoramD0 Apr 22, 2021
e2e747e
MicroDAGR - Add mode switching keybinds (#8216)
JoramD0 Apr 22, 2021
996bbd2
RHS ARF Compat - Fix RPK74M wrong ammo bug (#8223)
Dabako Apr 22, 2021
e6d337a
Extensions - Various Improvments (#8227)
PabstMirror Apr 22, 2021
cc0d8a5
Translations - Spanish (#8229)
regiregi22 Apr 26, 2021
825596b
Attach - Added attached/detaching events (#8193)
dedmen Apr 26, 2021
c425b35
Markers - Fix marker scale (#8233)
PabstMirror Apr 26, 2021
4726108
Cargo - paradrop fixes (#8203)
LupusTheCanine May 1, 2021
00eead4
Parachute - Add failure chance (#8226)
JoramD0 May 1, 2021
078a0b6
Bump lodash from 4.17.20 to 4.17.21 in /docs/src (#8244)
dependabot[bot] May 6, 2021
e6de643
Bump grunt from 1.0.4 to 1.3.0 in /docs/src (#8246)
dependabot[bot] May 7, 2021
173f86f
Bump hosted-git-info from 2.5.0 to 2.8.9 in /docs/src (#8247)
dependabot[bot] May 8, 2021
a715a5f
Markers - Fix JIP scale (#8248)
jonpas May 9, 2021
ede5c1d
Night Vision - Add color variants to all generations (#8209)
JoramD0 May 9, 2021
e082d75
Fix wrong shot size in birdshot strings (#8253)
Drofseh May 9, 2021
d3de5a9
Patachute - Add sound effect when cutting (#8239)
PabstMirror May 20, 2021
52116c7
Changes poisson disc to centered random. (#8257)
LorenLuke May 20, 2021
9122535
Fix tabs and manpad UBC
PabstMirror May 21, 2021
e5f791d
Merge branch 'master' into pr/8215
PabstMirror May 23, 2021
e3e3605
fix tabs in aim9
PabstMirror May 23, 2021
f89bf62
progress update: tercom now flies to acquisition basket
TheCandianVendingMachine May 23, 2021
597e188
Merge branch 'missileDynamics' of https://github.com/TheCandianVendin…
TheCandianVendingMachine May 23, 2021
e6fcd11
add TERCOM state defines
TheCandianVendingMachine May 25, 2021
7cf29ba
work on parsing heightmap
TheCandianVendingMachine Jun 1, 2021
79c6bf9
Change GBU navigation
TheCandianVendingMachine Jun 2, 2021
4308d33
remove testing constants
TheCandianVendingMachine Jun 7, 2021
8142bb0
remove TERCOM guidance
TheCandianVendingMachine Jun 12, 2021
038c82a
better JDAM simulation
TheCandianVendingMachine Jun 12, 2021
d8eb425
Better flare decoy calculation
TheCandianVendingMachine Jun 12, 2021
5acc277
Update 9m14_joystick.p3d
PabstMirror Jul 2, 2021
d50491f
Destroy projectile on all clients
TheCandianVendingMachine Jul 2, 2021
25b1b47
Merge branch 'missileDynamics' of https://github.com/TheCandianVendin…
TheCandianVendingMachine Jul 2, 2021
aff19ec
fix NLAW navigation profile
TheCandianVendingMachine Aug 2, 2021
7b7d79f
fix uninitialised values
TheCandianVendingMachine Aug 2, 2021
76c5c6e
make over-fly trajectory over-fly
TheCandianVendingMachine Aug 2, 2021
98e66d2
remove malyutka
TheCandianVendingMachine Aug 2, 2021
82c14a0
SACLOS tweaks
TheCandianVendingMachine Aug 2, 2021
9595640
Merge remote-tracking branch 'ACERemote/master' into missileDynamics
TheCandianVendingMachine Oct 16, 2021
120d16c
small changes
TheCandianVendingMachine Oct 16, 2021
0123216
fix bug in laser
TheCandianVendingMachine Oct 16, 2021
17e211e
Merge branch 'laserRevert' into missileDynamics
TheCandianVendingMachine Oct 16, 2021
9a2d631
make pronav use the correct units
TheCandianVendingMachine Oct 16, 2021
10c2019
change back
TheCandianVendingMachine Oct 16, 2021
34c7b57
add dev function to get ammo which has MG class data
TheCandianVendingMachine Oct 16, 2021
d8ebc35
improve lin navigation
TheCandianVendingMachine Oct 17, 2021
7f398a8
Merge branch 'master' into pr/8215
PabstMirror Oct 21, 2021
b40903b
Merge branch 'master' into pr/8215
PabstMirror Nov 13, 2021
a26e269
Minor style
PabstMirror Nov 13, 2021
f9ea835
add spike ATGM
TheCandianVendingMachine Dec 12, 2021
36f148d
Allow multiple cameras to exist at once. Fix script error
TheCandianVendingMachine Dec 12, 2021
c6c313a
fix bug with angles close to 0
TheCandianVendingMachine Dec 12, 2021
7d009d2
remove debug
TheCandianVendingMachine Dec 12, 2021
7460bb3
misc updates
TheCandianVendingMachine Dec 12, 2021
8da028b
Handle pre-tracking
TheCandianVendingMachine Dec 12, 2021
e91b8bc
Tweak target acquisition. Reset target after shooting
TheCandianVendingMachine Dec 13, 2021
becc9d2
Tweak how targets are acquired. Fix velocity calculation
TheCandianVendingMachine Dec 13, 2021
fd5b8a2
tweak navigation to allow for <200m shots
TheCandianVendingMachine Dec 14, 2021
7bb7b6f
enhance target designation
TheCandianVendingMachine Jan 2, 2022
d8554eb
Stringtable addition
TheCandianVendingMachine Jan 2, 2022
745a47f
Config changes
TheCandianVendingMachine Jan 2, 2022
5b4e29a
Merge branch 'missileDynamics' of github.com:TheCandianVendingMachine…
TheCandianVendingMachine Jan 2, 2022
9452de5
Merge branch 'master' of https://github.com/acemod/ACE3 into missileD…
TheCandianVendingMachine Jan 2, 2022
20ad628
more SACLOS tweaks
TheCandianVendingMachine Jan 2, 2022
e318e85
Some minor fixes
PabstMirror Jan 6, 2022
ad2842b
fix undefined array
TheCandianVendingMachine Jan 10, 2022
c2ef6b8
Merge branch 'missileDynamics' of github.com:TheCandianVendingMachine…
TheCandianVendingMachine Jan 10, 2022
97f3bb3
Only play sound when Spike is launcher. Change onFired to missileguid…
TheCandianVendingMachine Jan 14, 2022
56c85fc
Tweak IR seeker. Fix MCLOS fired from vehicles
TheCandianVendingMachine Feb 16, 2022
f9241fe
Remove debug sets
TheCandianVendingMachine Feb 16, 2022
71e01a2
Update all Line guidance missiles
TheCandianVendingMachine Apr 5, 2022
f79dde5
remove debug sets
TheCandianVendingMachine Apr 5, 2022
76bb679
Merge branch 'master' into pr/8215
PabstMirror Apr 16, 2022
67fe609
tweak javelin to make minimum ranges more realistic
TheCandianVendingMachine May 14, 2022
d944f09
Merge branch 'missileDynamics' of github.com:TheCandianVendingMachine…
TheCandianVendingMachine May 14, 2022
2041c88
Merge branch 'master' into pr/8215
PabstMirror May 24, 2022
f4152ec
cut spike
TheCandianVendingMachine Jun 3, 2022
e46cd2c
add better error messaging
TheCandianVendingMachine Jun 3, 2022
0b7c89a
better debug info
TheCandianVendingMachine Jun 3, 2022
0531abb
Rewrite documentation
TheCandianVendingMachine Jun 3, 2022
5a55d2d
Add ability to disable iron dome (disabled by default)
TheCandianVendingMachine Jun 3, 2022
bcd753f
Change name
TheCandianVendingMachine Jun 3, 2022
a79f987
fix typo
TheCandianVendingMachine Jun 3, 2022
743add1
Remove null projectiles from iron dome nonTrackingProjectiles
SzwedzikPL Jul 25, 2022
6aba4b0
Merge pull request #4 from SzwedzikPL/irondome-cleanupprojectiles
TheCandianVendingMachine Jul 25, 2022
3573aef
HEMTT v10 Compatibility
BrettMayson Nov 28, 2022
2fb1f00
Update addons/field_rations/CfgUIGrids.hpp
BrettMayson Dec 4, 2022
f4ea561
fix PabstMirror review
BrettMayson Dec 6, 2022
2f05c99
optionals
BrettMayson Dec 7, 2022
832b0c9
Merge remote-tracking branch 'brett/hemtt_v10'
TheCandianVendingMachine Jan 19, 2023
16dee0a
Merge branch 'master' into pr/8215
PabstMirror Jan 20, 2023
abef4fd
Merge branch 'master' into missileDynamics
TheCandianVendingMachine Jan 20, 2023
0957a33
Change configs to enclose strings for calculations
TheCandianVendingMachine Jan 21, 2023
01ac87d
Fix NLAW guidance that was causing massive overfly
TheCandianVendingMachine Jan 21, 2023
d1f5791
make tweaks for PLOS movement path
TheCandianVendingMachine Jan 21, 2023
3af5717
fix NLAW overfly
TheCandianVendingMachine Jan 31, 2023
28c166d
Merge branch 'master' into pr/8215
PabstMirror Feb 24, 2023
7727fee
Fix hemmit merge
PabstMirror Feb 24, 2023
2c0a720
Merge branch 'master' into pr/8215
PabstMirror Sep 9, 2023
6e6d24a
fix header
PabstMirror Sep 9, 2023
10065f7
Update fnc_seekerType_SACLOS.sqf
PabstMirror Sep 10, 2023
477bdd0
Merge branch 'master' into pr/8215
PabstMirror Oct 7, 2023
b5bae13
Update to new include paths
PabstMirror Oct 7, 2023
f45c56a
Update fnc_midCourseTransition.sqf
PabstMirror Oct 7, 2023
4197a6e
Merge branch 'master' into pr/8215
PabstMirror Jan 7, 2024
825f40b
initSettings.inc.sqf
PabstMirror Jan 7, 2024
b5d0ae6
Merge branch 'master' into pr/8215
PabstMirror Mar 28, 2024
6485898
Merge branch 'master' into pr/8215
PabstMirror Apr 12, 2024
8aab5c4
Merge branch 'master' into pr/8215
PabstMirror May 24, 2024
f75f3d3
Remove weapon additions
TheCandianVendingMachine May 27, 2024
cbcc642
revert old weapons, pt1
TheCandianVendingMachine May 27, 2024
074fc36
revert pt2
TheCandianVendingMachine May 27, 2024
909a028
readd javelin
TheCandianVendingMachine May 27, 2024
bb4ff28
split iron dome
TheCandianVendingMachine May 27, 2024
af5f7d3
cleanup laser
TheCandianVendingMachine May 27, 2024
1270d17
remove GPS files
TheCandianVendingMachine May 27, 2024
744cd45
remove gps definitions
TheCandianVendingMachine May 27, 2024
972ad68
remove IR
TheCandianVendingMachine May 28, 2024
46aa1ae
remove MCLOS
TheCandianVendingMachine May 28, 2024
87c819f
remove doppler
TheCandianVendingMachine May 28, 2024
9ebd8fd
final cleanup
TheCandianVendingMachine May 28, 2024
607cc8c
restore final final i promise
TheCandianVendingMachine May 28, 2024
bcb6ed7
cleanup arbitrary files
TheCandianVendingMachine May 28, 2024
ec608b2
Separate iron dome
TheCandianVendingMachine May 28, 2024
02c1d79
small cleanup
PabstMirror May 30, 2024
54f7494
fix hemtt warnings
PabstMirror May 30, 2024
2e23f61
Merge branch 'master' into missile_guidance_rewrite
PabstMirror Jun 20, 2024
ed260fc
cleanup unused var
PabstMirror Jun 20, 2024
1819cad
fix preping some missing files (jdam/doppler)
PabstMirror Jun 22, 2024
c70cb4f
Merge branch 'master' into missile_guidance_rewrite
PabstMirror Jul 29, 2024
98f957e
move cam func
PabstMirror Jul 29, 2024
fcf817a
Merge branch 'master' into missile_guidance_rewrite
PabstMirror Aug 18, 2024
7376a88
Merge branch 'master' into missile_guidance_rewrite
PabstMirror Aug 23, 2024
cfaa658
Merge branch 'missile_guidance_rewrite' into iron_dome
PabstMirror Aug 23, 2024
28e8578
Merge branch 'master' into iron_dome
PabstMirror Sep 21, 2024
6caca8c
Merge branch 'master' into iron_dome
PabstMirror Nov 22, 2024
8129abf
sort st
PabstMirror Nov 22, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions addons/iron_dome/$PBOPREFIX$
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
z\ace\addons\iron_dome
17 changes: 17 additions & 0 deletions addons/iron_dome/CfgEventHandlers.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
class Extended_PreStart_EventHandlers {
class ADDON {
init = QUOTE(call COMPILE_FILE(XEH_preStart));
};
};
class Extended_PreInit_EventHandlers {
class ADDON {
init = QUOTE(call COMPILE_FILE(XEH_preInit));
};
};

class Extended_PostInit_EventHandlers {
class ADDON {
init = QUOTE(call COMPILE_SCRIPT(XEH_postInit));
};
};

11 changes: 11 additions & 0 deletions addons/iron_dome/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
ace_iron_dome
===================

Adds an Iron Dome projectile interceptor system


## Maintainers

The people responsible for merging changes to this component or answering potential questions.

- [Dani (TCVM)](https://github.com/TheCandianVendingMachine)
2 changes: 2 additions & 0 deletions addons/iron_dome/XEH_PREP.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
PREP(projectileTrackerPFH);
PREP(proximityFusePFH);
7 changes: 7 additions & 0 deletions addons/iron_dome/XEH_postInit.sqf
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
#include "script_component.hpp"

if (isServer && { GVAR(enable) }) then {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A boolean check is too cheap for lazy eval.

I just tested that without lazy eval (isServer && true) it takes 0.0011ms - 0.0027ms, whereas with lazy eval (isServer && {true}) it always takes at least 0.0015ms (most of the time), sometimes up to 0.0045ms.

Suggested change
if (isServer && { GVAR(enable) }) then {
if (isServer && GVAR(enable)) then {

[LINKFUNC(projectileTrackerPFH)] call CBA_fnc_addPerFrameHandler;
[LINKFUNC(proximityFusePFH)] call CBA_fnc_addPerFrameHandler;
};

97 changes: 97 additions & 0 deletions addons/iron_dome/XEH_preInit.sqf
Original file line number Diff line number Diff line change
@@ -0,0 +1,97 @@
#include "script_component.hpp"

ADDON = false;

PREP_RECOMPILE_START;
#include "XEH_PREP.hpp"
PREP_RECOMPILE_END;

#include "initSettings.inc.sqf"

// Server handles the tracking of all projectiles. It dispatches events to launchers to fire at specific targets
// The tracker and launcher array are global to allow for early-out if it is impossible to kill any projectiles to avoid wasting bandwidth
GVAR(trackers) = [];
GVAR(launchers) = [];

if (isServer) then {
GVAR(nonTrackingProjectiles) = [];
GVAR(trackingProjectiles) = [];

GVAR(interceptors) = [];
// Put these into hash table to avoid massive amounts of loops
GVAR(toBeShot) = call CBA_fnc_hashCreate;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

HashMaps are in vanilla already, though.


[QGVAR(track), {
params ["_projectile"];
GVAR(nonTrackingProjectiles) pushBack _projectile;
}] call CBA_fnc_addEventHandler;

[QGVAR(registerInterceptor), {
params ["_interceptor", "_target"];
GVAR(interceptors) pushBack [_interceptor, _target, getPosASLVisual _interceptor, _interceptor distance _target];
[GVAR(toBeShot), _target] call CBA_fnc_hashRem;
}] call CBA_fnc_addEventHandler;
};

[QGVAR(registerLaunchers), {
{
GVAR(launchers) pushBackUnique _x;
_x setVariable [QGVAR(targetList), []];
_x setVariable [QGVAR(launchState), LAUNCH_STATE_IDLE];
_x setVariable [QGVAR(lastLaunchTime), 0];
_x setVariable [QGVAR(engagedTargets), [[], objNull] call CBA_fnc_hashCreate];
_x setVariable [QEGVAR(missileguidance,target), objNull];

if (local _x) then {
_x addEventHandler ["Fired", {
params ["_launcher", "", "", "", "", "", "_projectile"];
private _target = _launcher getVariable [QEGVAR(missileguidance,target), objNull];
if !(isNull _target) then {
[QGVAR(registerInterceptor), [_projectile, _target]] call CBA_fnc_serverEvent;
};
}];
};
} forEach _this;
}] call CBA_fnc_addEventHandler;

[QGVAR(registerTrackers), {
{
_x params ["_tracker", "_range"];
GVAR(trackers) pushBack [_tracker, _range];
} forEach _this;
}] call CBA_fnc_addEventHandler;

// When something is fired, determine if we want to track it. If so, send it to the server for processing
GVAR(projectilesToIntercept) = [];

[QGVAR(addProjectilesToIntercept), {
{
GVAR(projectilesToIntercept) pushBackUnique _x;
} forEach _this;
}] call CBA_fnc_addEventHandler;

["All", "fired", {
params ["", "", "", "", "", "", "_projectile"];
if (local _projectile && { (typeOf _projectile) in GVAR(projectilesToIntercept) }) then {
// avoid extra bandwidth: don't make a call to the server if we don't have any systems up
GVAR(launchers) = GVAR(launchers) select {
alive _x
};
GVAR(trackers) = GVAR(trackers) select {
_x params ["_tracker"];
alive _tracker
};
if !(GVAR(launchers) isEqualTo [] || { GVAR(trackers) isEqualTo [] }) then {
[QGVAR(track), [_projectile]] call CBA_fnc_serverEvent;
};
};
}] call CBA_fnc_addClassEventHandler;

// Needed on all clients to properly destroy it. Despite the fact that deleteVehicle is AG EG, unless if you delete it on all clients there will still be missiles seen
[QGVAR(destroyProjectile), {
params ["_projectile"];
deleteVehicle _projectile;
}] call CBA_fnc_addEventHandler;

ADDON = true;

3 changes: 3 additions & 0 deletions addons/iron_dome/XEH_preStart.sqf
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
#include "script_component.hpp"

#include "XEH_PREP.hpp"
19 changes: 19 additions & 0 deletions addons/iron_dome/config.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
#include "script_component.hpp"

class CfgPatches {
class ADDON {
name = COMPONENT_NAME;
units[] = {};
weapons[] = {};
requiredVersion = REQUIRED_VERSION;
// no point having this system without missile guidance: nothing would happen
requiredAddons[] = {"ace_common","ace_missileguidance"};
author = ECSTRING(common,ACETeam);
authors[] = {"Dani (TCVM)"};
url = ECSTRING(main,URL);
VERSION_CONFIG;
};
};

#include "CfgEventHandlers.hpp"

204 changes: 204 additions & 0 deletions addons/iron_dome/functions/fnc_projectileTrackerPFH.sqf
Original file line number Diff line number Diff line change
@@ -0,0 +1,204 @@
#include "..\script_component.hpp"
/*
* Author: tcvm
* Handles tracking of incoming projectiles per frame
*
* Arguments:
* 0: Args <ARRAY>
* 1: Handle <NUMBER>
*
* Return Value:
* None
*
* Example:
* [ace_iron_dome_projectileTrackerPFH] call CBA_fnc_addPerFrameHandler
*
* Public: No
*/

GVAR(trackers) = GVAR(trackers) select {
_x params ["_tracker", "_range"];
#ifdef DRAW_TRACKING_INFO
drawIcon3D ["\a3\ui_f\data\IGUI\Cfg\Cursors\selectover_ca.paa", [1,1,0,1], getPos _tracker, 0.75, 0.75, 0, format ["TRACKER [%1m]", _range], 1, 0.025, "TahomaB"];
#endif
alive _tracker
};

GVAR(launchers) = GVAR(launchers) select {
alive _x
};

[GVAR(toBeShot), {
(CBA_missionTime - _value) < GVAR(targetRecycleTime)
}] call CBA_fnc_hashFilter;

private _idleLaunchers = GVAR(launchers) select {
(_x getVariable QGVAR(launchState)) isEqualTo LAUNCH_STATE_IDLE && { someAmmo _x }
};

// no point filtering if we don't have a launcher. Don't waste cycles
if (_idleLaunchers isNotEqualTo []) then {

GVAR(nonTrackingProjectiles) = GVAR(nonTrackingProjectiles) select {
private _projectile = _x;
if (isNull _projectile) then {continueWith false};

private _keep = true;
private _bestRange = 1e10;

{
_x params ["_tracker", "_range"];
_bestRange = _bestRange min (_projectile distanceSqr _tracker);
if (_projectile distanceSqr _tracker <= _range * _range) exitWith {
GVAR(trackingProjectiles) pushBack [_projectile, 0];
_keep = false;
[QGVAR(projectileInRange), [_projectile, _tracker]] call CBA_fnc_localEvent;
};
} forEach GVAR(trackers);

#ifdef DRAW_TRACKING_INFO
drawIcon3D ["\a3\ui_f\data\IGUI\Cfg\Cursors\selectover_ca.paa", [1,0,0,1], getPos _projectile, 0.75, 0.75, 0, format ["%1 %2m", typeOf _projectile, sqrt _bestRange], 1, 0.025, "TahomaB"];
#endif

_keep
};

GVAR(trackingProjectiles) = GVAR(trackingProjectiles) select {
_x params ["_projectile", "_lastFired"];

private _keep = false;
if (alive _projectile) then {
{
_x params ["_tracker", "_range"];
private _withinRange = _projectile distanceSqr _tracker <= _range * _range;

if (_withinRange) exitWith {
_keep = true;
};

} forEach GVAR(trackers);

if !(_keep) then {
GVAR(nonTrackingProjectiles) pushBack _projectile;
} else {
private _bestLauncher = objNull;
private _bestAmmo = 0;

private _engagedFuture = [GVAR(toBeShot), _projectile] call CBA_fnc_hashHasKey;

private _engagedPast = GVAR(interceptors) findIf {
_x params ["", "_target"];
_projectile isEqualTo _target;
};

private _engaged = _engagedFuture || (_engagedPast != -1);
if !(_engaged) then {
// launch a missile
// pick first idle launcher. Could use a heuristic, but that would require O(k*l) operations, and that could be a lot
// 20 launchers * 100 projectiles = 2000 loops. Way too slow
private _bestLauncher = _idleLaunchers select 0;
_idleLaunchers deleteAt 0;

private _targetList = _bestLauncher getVariable QGVAR(targetList);
_targetList pushBackUnique _projectile;
_bestLauncher setVariable [QGVAR(targetList), _targetList];

// avoid re-engaging same target
[GVAR(toBeShot), _projectile, CBA_missionTime] call CBA_fnc_hashSet;
};

#ifdef DRAW_TRACKING_INFO
drawIcon3D ["\a3\ui_f\data\IGUI\Cfg\Cursors\selectover_ca.paa", [0,1,0,1], getPos _projectile, 0.75, 0.75, 0, format ["%1 %2m %3s", typeOf _projectile, _bestLauncher distance _projectile], 1, 0.025, "TahomaB"];
#endif
};
};

_keep
};
};

{
private _launcher = _x;
private _state = _launcher getVariable QGVAR(launchState);

switch (_state) do {
case LAUNCH_STATE_IDLE: {
private _targetList = _x getVariable QGVAR(targetList);
private _engagedTargets = _x getVariable QGVAR(engagedTargets);

_targetList = _targetList select {
private _timeFiredAt = [_engagedTargets, _x, 0] call CBA_fnc_hashGet;
alive _x && (_timeFiredAt == 0 || { (CBA_missionTime - _timeFiredAt) >= GVAR(targetRecycleTime) })
};

private _bestTarget = objNull;
private _bestDistance = 1e10;
{
if (_x distanceSqr _launcher < _bestDistance) then {
_bestTarget = _x;
_bestDistance = _x distanceSqr _launcher;
};
} forEach _targetList;

if !(isNull _bestTarget) then {
_launcher setVariable [QEGVAR(missileguidance,target), _bestTarget];
_launcher setVariable [QGVAR(launchState), LAUNCH_STATE_TRACKING];
};

#ifdef DRAW_TRACKING_INFO
drawIcon3D ["\a3\ui_f\data\IGUI\Cfg\Cursors\selectover_ca.paa", [1, 1, 1, 1], getPos _launcher, 0.75, 0.75, 0, format ["IDLE [AMMO: %1]", someAmmo _launcher], 1, 0.025, "TahomaB"];
#endif
};
case LAUNCH_STATE_TRACKING: {
private _target = _launcher getVariable QEGVAR(missileguidance,target);
_launcher lookAt getPosVisual _target;

if (isNull _target) then {
_launcher setVariable [QGVAR(launchState), LAUNCH_STATE_IDLE];
} else {
private _directionToTarget = (getPosASLVisual _launcher) vectorFromTo (getPosASLVisual _target);
private _turretDirection = _launcher weaponDirection currentWeapon _launcher;
private _localDirection = _launcher vectorWorldToModelVisual _turretDirection;

private _elevation = 90 - ((_localDirection#1) atan2 (_localDirection#2));
private _angle = acos (_turretDirection vectorCos _directionToTarget);

if (_angle <= GVAR(launchAcceptableAngle) && _elevation >= GVAR(launchAcceptableElevation)) then {
_launcher setVariable [QGVAR(launchState), LAUNCH_STATE_FIRING];
};

#ifdef DRAW_TRACKING_INFO
drawIcon3D ["\a3\ui_f\data\IGUI\Cfg\Cursors\selectover_ca.paa", [0, 0, 1, 1], getPos _launcher, 0.75, 0.75, 0, format ["TRACKING: %1 %2", _angle, _elevation], 1, 0.025, "TahomaB"];
drawLine3D [getPos _launcher, getPos _target, [0, 0, 1, 1]];
#endif
};
};
case LAUNCH_STATE_FIRING: {
private _turret = [_launcher, (crew _launcher) select 0] call CBA_fnc_turretPath;
[_launcher, _launcher currentWeaponTurret _turret] call BIS_fnc_fire;

_launcher setVariable [QGVAR(lastLaunchTime), CBA_missionTime];
_launcher setVariable [QGVAR(launchState), LAUNCH_STATE_COOLDOWN];

private _target = _launcher getVariable QEGVAR(missileguidance,target);
private _engagedTargets = _x getVariable QGVAR(engagedTargets);
[_engagedTargets, _target, CBA_missionTime] call CBA_fnc_hashSet;
_x setVariable [QGVAR(engagedTargets), _engagedTargets];

#ifdef DRAW_TRACKING_INFO
drawIcon3D ["\a3\ui_f\data\IGUI\Cfg\Cursors\selectover_ca.paa", [1, 0, 0, 1], getPos _launcher, 0.75, 0.75, 0, format ["FIRING"], 1, 0.025, "TahomaB"];
#endif
};
case LAUNCH_STATE_COOLDOWN: {
private _lastLaunchTime = _launcher getVariable QGVAR(lastLaunchTime);
if (CBA_missionTime - _lastLaunchTime >= GVAR(timeBetweenLaunches)) then {
_launcher setVariable [QGVAR(launchState), LAUNCH_STATE_IDLE];
};

#ifdef DRAW_TRACKING_INFO
drawIcon3D ["\a3\ui_f\data\IGUI\Cfg\Cursors\selectover_ca.paa", [0, 0, 1, 1], getPos _launcher, 0.75, 0.75, 0, format ["COOLDOWN %1", CBA_missionTime - _lastLaunchTime], 1, 0.025, "TahomaB"];
#endif
};
};
} forEach GVAR(launchers);

Loading
Loading