Skip to content

Commit

Permalink
missile_AIM120 - Add, create Doppler seeker (#10021)
Browse files Browse the repository at this point in the history
* enable chaff decoy

* add config entries

* Implement optical mavericks

* Allow for debug info to be displayed via variable

* Change AIM-9 agility

* update dragon to not use new guidance

* Tweak flight parameters. Add R-77

* Add AIM-120A

* add ASRAAM

* add R-73/4

* Add all GBU-12s that exist for all planes

* update todo

* update todo for ground based weapons

* Add GPS selector dialog for GPS munitions

* add TOO TGP

* Add SDB and JDAM

* update todo

* fix gimbal lock via rotating with quaternions

* tweak JDAM guidance

* Better attack angle calculation. Does not get exactly right, but works for all cases.

Need to implement a PID controller navigation type to get a correct attack angle

* Fix SACLOS missiles

* Fix NLAW and PLOS

The missile pitches up due to initial angle stuff. I don't know if this is behaviour we want to fix or not?

* update todo

* update todo

* Add Vikhr ATGM

* Add long range SAMs

* fix SAM animations

* Add all ground based missiles. Tweak AIM-9 flare angle

* remove debugh print

* Fix Wiesel ATGM animation. Tweak SACLOS values

* Add action to get into jdam settings

* fix all script components

* Add paremter to allow weathervaning

Weapons usually tend toward the velocity vector due to aerodynamics - calculate side slip and use calculation to do this

* Add new navigation profile. Tweak javelin mid-course guidance

* Process all navigation onFired. Send the correct array to function

* fix missing semicolons

* Add hellfire mid course guidance

* Tweak hellfire attack profile

* change how IR seeker performs

The angle check is better now. Relative velocites guarenteed

* tabs -> spaces

* localise aim120

* localise aim9

* localise gbu

* fix IR tracker losing lock immediately due to being blocked by launcher

* localise manpad

* actually localise manpad

* localise maverick

* localise missile guidance

* localise sam

* localise sdb

* localise vikhr

* tabs -> spaces again

* init commit 9m14

* update stringtables so they are in titlecase

* crash on load

* perplexed

* fix game crashing on load

* Add joystick model

* Add realistic 9m14 behaviour

the 9m14 control joystick can attach 4 9m14 launchers at a time. Replicate that here

* add MCLOS guidance

* add the ability to see a light trail

* tweak HOT guidance params

* tweak metis guidance params

* tweak Vikhr guidance

* add trail to vikhr

* Add Iron Dome interceptor API

* Optimise iron dome

* Only launch if we are above a threshold angle

* add local event for mission makers

* change events to allow for any number of arguments

* avoid making un-needed calls to the server

* Update doppler seeker to allow the tracking and killing of projectiles

* Avoid overshooting target

* Add settings for various things

* Add missile hiding for malyutka

* init commit of cruise missile

* Various - Add missing units/weapons to cfgPatches (#8175)

* Various - Add missing units/weapons to cfgPatches

* Update config.cpp

* Documentation - Add Mikero binarization note (#8172)

* Bump is-svg from 4.2.1 to 4.3.1 in /docs/src (#8177)

Bumps [is-svg](https://github.com/sindresorhus/is-svg) from 4.2.1 to 4.3.1.
- [Release notes](https://github.com/sindresorhus/is-svg/releases)
- [Commits](sindresorhus/is-svg@v4.2.1...v4.3.1)

Signed-off-by: dependabot[bot] <[email protected]>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Adjust "New issue" link to lead to template selection page (#8182)

We want people to choose a template when creating a new issue

* Update linguist settings (#8151)

* Typo in usage example (#8201)

* Mk6 Mortar - Fix README.md typo (#8205)

* Overhaul CSW docs (#8206)

* Medical - Add Alternative Survival Chance (#8192)

Co-authored-by: TyroneMF <[email protected]>
Co-authored-by: Filip Maciejewski <[email protected]>
Co-authored-by: Kyle Mckay <[email protected]>

* Fix make.py temp files cleanup (#8189)

* Fix Injured Sounds Not Playing At Altitudes Above 70 (#8212)

* Particles - Fix macro (#8214)

* initial push

* Update script_component.hpp

* Update script_component.hpp

* Update script_component.hpp

* Map - Fix stuck map compass size (add 0.1 zoom duration) (#8176)

Co-authored-by: jonpas <[email protected]>

* Medical - Allow unconscious unit in Taru pods (#8168)

Co-authored-by: Filip Maciejewski <[email protected]>

* Name Tags - Add ability to set custom rank icon (#8174)

* Tools - Add script to update HEMTT include folder (#8134)

* Tools - Add script to check sqf/config with sqfvm (#8137)

* Medical - Add Vehicle Crashes setting (#8149)

Co-authored-by: jonpas <[email protected]>

* Dragging - Add new dragging animations (#7950)

* New custom animation added

* Adjusted CfgMoves and the script components

* New drop animation and key handler

* CBA settings and new ManActions added

* Adjustments to the drop animation

* Added translations and fixed some stuff

* Update CfgMovesBasic.hpp

* Fix translations

Co-authored-by: Elgin675 <[email protected]>
Co-authored-by: Blutze <[email protected]>

* Use the same key to drop object

* Update addons/dragging/stringtable.xml

Co-authored-by: Jo David <[email protected]>

* Fix French translation

Co-authored-by: Elgin675 <[email protected]>

* Lower the weapon accuracy of the drag animations

* Removed auto-switch to handgun

* Update fnc_startDrag.sqf

 - Holding a launcher breaks the firing animation.
 - Now the unit has to hold either a primary weapon or handgun.

* Handle the unit's current weapon

Co-authored-by: BaerMitUmlaut <[email protected]>

* Update addons/dragging/functions/fnc_handlePlayerWeaponChanged.sqf

Co-authored-by: Filip Maciejewski <[email protected]>

* Update addons/dragging/initSettings.sqf

Co-authored-by: Elgin675 <[email protected]>
Co-authored-by: Blutze <[email protected]>
Co-authored-by: Jo David <[email protected]>
Co-authored-by: BaerMitUmlaut <[email protected]>
Co-authored-by: Filip Maciejewski <[email protected]>
Co-authored-by: jonpas <[email protected]>

* Dragging - Fix build issue (#8219)

* Documentation - Remove DeTex requirement (#8220)

DeTex is subscriber-only now, not required for building ACE3.

* User Interface - Add setting for Development Build watermark (#8140)

Co-authored-by: jonpas <[email protected]>

* RHS USAF Compat - Nightforce NXS scopes updated (#8222)

* Interact Menu - Make List default (#8217)

* Markers - Add scale slider (#8059)

Co-authored-by: commy2 <[email protected]>
Co-authored-by: PabstMirror <[email protected]>
Co-authored-by: jonpas <[email protected]>

* Initial push (#8225)

* MicroDAGR - Add mode switching keybinds (#8216)

* Initial push

* Mode cycling

* Use defines

* RHS ARF Compat - Fix RPK74M wrong ammo bug (#8223)

* Fixed RPK74M wrong ammo bug

* Fix wrong deleted lines of code

* Edit rjs_weap_rpk74_base to rhs_weap_rpk_base

Co-authored-by: Dabako <[email protected]>
Co-authored-by: PabstMirror <[email protected]>

* Extensions - Various Improvments (#8227)

* Translations - Spanish (#8229)

Complete to date spanish translation.

* Attach - Added attached/detaching events (#8193)

* Added ace_attach attached/detach events

* Apply suggestions from code review

Co-authored-by: Jo David <[email protected]>

* Apply suggestions from code review

Co-authored-by: jonpas <[email protected]>

Co-authored-by: Jo David <[email protected]>
Co-authored-by: jonpas <[email protected]>

* Markers - Fix marker scale (#8233)

* Cargo - paradrop fixes (#8203)

* Small fixes in ace_cargo

Makes paradropItem and unloadItem invoke event "ace_cargoUnloaded" with parameters _itemObject, _vehicle and "paradrop" or "unload" respectivelty.
paradropItem invoked said event but if item was classname it would send classname to event which is not particularly useful.

* Update XEH_postInit.sqf

Moved event invocation to unloadItem, this provides ability to always pass object to eventhandlers.

* code refactor

refactored according to #8203 (comment)

* Update fnc_paradropItem.sqf

apply new fix

* Revert "Update fnc_paradropItem.sqf"

This reverts commit 3db5cc1.

* Update fnc_paradropItem.sqf

fixed hint that was broken by previous fixes

* style check

Co-authored-by: commy2 <[email protected]>

* style check

Co-authored-by: commy2 <[email protected]>

* naming convention

replaced object references called _item with _object.

* Update fnc_paradropItem.sqf

Co-authored-by: commy2 <[email protected]>

* Parachute - Add failure chance (#8226)

* Initial push

* disable forgotten define

* Improve exitWith check

* Requested/suggested changes

* Requested changes

* Requested changes

* Bump lodash from 4.17.20 to 4.17.21 in /docs/src (#8244)

Bumps [lodash](https://github.com/lodash/lodash) from 4.17.20 to 4.17.21.
- [Release notes](https://github.com/lodash/lodash/releases)
- [Commits](lodash/lodash@4.17.20...4.17.21)

Signed-off-by: dependabot[bot] <[email protected]>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Bump grunt from 1.0.4 to 1.3.0 in /docs/src (#8246)

Bumps [grunt](https://github.com/gruntjs/grunt) from 1.0.4 to 1.3.0.
- [Release notes](https://github.com/gruntjs/grunt/releases)
- [Changelog](https://github.com/gruntjs/grunt/blob/main/CHANGELOG)
- [Commits](gruntjs/grunt@v1.0.4...v1.3.0)

Signed-off-by: dependabot[bot] <[email protected]>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Bump hosted-git-info from 2.5.0 to 2.8.9 in /docs/src (#8247)

Bumps [hosted-git-info](https://github.com/npm/hosted-git-info) from 2.5.0 to 2.8.9.
- [Release notes](https://github.com/npm/hosted-git-info/releases)
- [Changelog](https://github.com/npm/hosted-git-info/blob/v2.8.9/CHANGELOG.md)
- [Commits](npm/hosted-git-info@v2.5.0...v2.8.9)

Signed-off-by: dependabot[bot] <[email protected]>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Markers - Fix JIP scale (#8248)

* Night Vision - Add color variants to all generations (#8209)

* Fix wrong shot size in birdshot strings (#8253)

* Patachute - Add sound effect when cutting (#8239)

* Changes poisson disc to centered random. (#8257)

It looks nicer and distributes more realistically. I don't know what I was thinking when I first put in poisson disc.

* Fix tabs and manpad UBC

* fix tabs in aim9

* progress update: tercom now flies to acquisition basket

* add TERCOM state defines

* work on parsing heightmap

* Change GBU navigation

* remove testing constants

* remove TERCOM guidance

* better JDAM simulation

Attack heading and impact angle now are followed better

* Better flare decoy calculation

* Update 9m14_joystick.p3d

removed p:\ part from proxy path:
was: `\p:\a3\data_f\proxies\gunner_static_low01\gunner.p3d`

* Destroy projectile on all clients

The projectile needs to be destroyed on all clients to stop it from being simulated. If not destroyed where projectile is local, it will still explode when hitting the ground. If not destroyed on remote clients, the projectile will still be visible but deal no damage

* fix NLAW navigation profile

* fix uninitialised values

* make over-fly trajectory over-fly

* remove malyutka

* SACLOS tweaks

* small changes

* fix bug in laser

* make pronav use the correct units

* change back

* add dev function to get ammo which has MG class data

* improve lin navigation

* Minor style

* add spike ATGM

* Allow multiple cameras to exist at once. Fix script error

* fix bug with angles close to 0

* remove debug

* misc updates

* Handle pre-tracking

* Tweak target acquisition. Reset target after shooting

* Tweak how targets are acquired. Fix velocity calculation

* tweak navigation to allow for <200m shots

* enhance target designation

* Stringtable addition

* Config changes

* more SACLOS tweaks

* Some minor fixes

* fix undefined array

* Only play sound when Spike is launcher. Change onFired to missileguidance

* Tweak IR seeker. Fix MCLOS fired from vehicles

* Remove debug sets

* Update all Line guidance missiles

* remove debug sets

* tweak javelin to make minimum ranges more realistic

* cut spike

* add better error messaging

* better debug info

* Rewrite documentation

* Add ability to disable iron dome (disabled by default)

* Change name

* fix typo

* Remove null projectiles from iron dome nonTrackingProjectiles

* HEMTT v10 Compatibility

* Update addons/field_rations/CfgUIGrids.hpp

Co-authored-by: PabstMirror <[email protected]>

* fix PabstMirror review

* optionals

* Change configs to enclose strings for calculations

* Fix NLAW guidance that was causing massive overfly

* make tweaks for PLOS movement path

* fix NLAW overfly

* Fix hemmit merge

* fix header

* Update fnc_seekerType_SACLOS.sqf

* Update to new include paths

* Update fnc_midCourseTransition.sqf

* initSettings.inc.sqf

* Remove weapon additions

* revert old weapons, pt1

* revert pt2

* readd javelin

* split iron dome

* cleanup laser

* remove GPS files

* remove gps definitions

* remove IR

* remove MCLOS

* remove doppler

* final cleanup

* restore final final i promise

* cleanup arbitrary files

* Isolate doppler

* restore files messed up by merge

* add aim120 definition

* Revert "remove doppler"

This reverts commit 87c819f.

* small cleanup

* fix hemtt warnings

* cleanup unused var

* fix preping some missing files (jdam/doppler)

* move cam func

* Update addons/aim120/$PBOPREFIX$

Co-authored-by: johnb432 <[email protected]>

* Fix preps

* apply comments

* Update fnc_seekerType_Doppler.sqf

* change addon name to standardize

* use standard missile defines

* Update macros

* update pboprefix

* Update command casing

* sort st, add annotation

---------

Co-authored-by: PabstMirror <[email protected]>
Co-authored-by: jonpas <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Jo David <[email protected]>
Co-authored-by: Filip Maciejewski <[email protected]>
Co-authored-by: Pascal Dunaj <[email protected]>
Co-authored-by: BaerMitUmlaut <[email protected]>
Co-authored-by: Brett <[email protected]>
Co-authored-by: TyroneMF <[email protected]>
Co-authored-by: Kyle Mckay <[email protected]>
Co-authored-by: Dystopian <[email protected]>
Co-authored-by: commy2 <[email protected]>
Co-authored-by: R3voA3 <[email protected]>
Co-authored-by: Steve Zhao <[email protected]>
Co-authored-by: Kyle J. McKeown <[email protected]>
Co-authored-by: Salluci <[email protected]>
Co-authored-by: Dániel Boros <[email protected]>
Co-authored-by: Elgin675 <[email protected]>
Co-authored-by: Blutze <[email protected]>
Co-authored-by: Laid3acK <[email protected]>
Co-authored-by: frankplow <[email protected]>
Co-authored-by: JoramD <[email protected]>
Co-authored-by: Dabako <[email protected]>
Co-authored-by: Dabako <[email protected]>
Co-authored-by: Abogado <[email protected]>
Co-authored-by: Dedmen Miller <[email protected]>
Co-authored-by: Lupus the Canine <[email protected]>
Co-authored-by: Drofseh <[email protected]>
Co-authored-by: LorenLuke <[email protected]>
Co-authored-by: SzwedzikPL <[email protected]>
Co-authored-by: BrettMayson <[email protected]>
Co-authored-by: johnb432 <[email protected]>
  • Loading branch information
1 parent 28ea1b6 commit 78f7451
Show file tree
Hide file tree
Showing 13 changed files with 767 additions and 2 deletions.
1 change: 1 addition & 0 deletions addons/missile_aim120/$PBOPREFIX$
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
z\ace\addons\missile_aim120
79 changes: 79 additions & 0 deletions addons/missile_aim120/CfgAmmo.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
class EGVAR(missileguidance,type_AMRAAM);
class EGVAR(missileguidance,type_R77);
class CfgAmmo {
class ammo_Missile_AMRAAM_C;
class M_Zephyr;
// AIM-120
class GVAR(a): M_Zephyr {
missileLockCone = 30;
missileKeepLockedCone = 30;
missileLockMaxDistance = 16000;
missileLockMinDistance = 500;

author = "Dani (TCVM)";
maneuvrability = 0;
flightProfiles[] = {"Direct", "Loft"};
class Direct {}; // dummy to allow for F cycling of missile mode
class Loft {};
class ace_missileguidance: EGVAR(missileguidance,type_AMRAAM) {
enabled = 1;
};
};

class GVAR(c): ammo_Missile_AMRAAM_C {
missileLockCone = 30;
missileKeepLockedCone = 30;
missileLockMaxDistance = 16000;
missileLockMinDistance = 500;

author = "Dani (TCVM)";
maneuvrability = 0;
flightProfiles[] = {"Direct", "Loft"};
class Direct {}; // dummy to allow for F cycling of missile mode
class Loft {};
class ace_missileguidance: EGVAR(missileguidance,type_AMRAAM) {
enabled = 1;
};
};

class ammo_Missile_AMRAAM_D;
class GVAR(d): ammo_Missile_AMRAAM_D {
missileLockCone = 45;
missileKeepLockedCone = 45;
missileLockMaxDistance = 16000;
missileLockMinDistance = 500;

author = "Dani (TCVM)";
maneuvrability = 0;
flightProfiles[] = {"Direct", "TopDown"};
class Direct {}; // dummy to allow for F cycling of missile mode
class TopDown {};
class ace_missileguidance: EGVAR(missileguidance,type_AMRAAM) {
enabled = 1;
pitchRate = 45;
yawRate = 45;
minimumSpeedFilter = 15; // filter out targets that have a closing velocity less than this
minimumTimeFilter = 0.00005; // filter out targets that are this close to the ground (speed of light)
maxTerrainCheck = 16000; // How far we should check for terrain
};
};

// R-77
class ammo_Missile_AA_R77;
class GVAR(r77): ammo_Missile_AA_R77 {
missileLockCone = 50;
missileKeepLockedCone = 50;
missileLockMaxDistance = 16000;
missileLockMinDistance = 500;

author = "Dani (TCVM)";
maneuvrability = 0;
flightProfiles[] = {"Direct", "TopDown"};
class Direct {}; // dummy to allow for F cycling of missile mode
class TopDown {};
class ace_missileguidance: EGVAR(missileguidance,type_R77) {
enabled = 1;
};
};
};

108 changes: 108 additions & 0 deletions addons/missile_aim120/CfgMagazines.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,108 @@
class CfgMagazines {
class magazine_Missile_AMRAAM_C_x1;
class PylonMissile_Missile_AMRAAM_C_x1;
class PylonRack_Missile_AMRAAM_C_x1;
class PylonRack_Missile_AMRAAM_C_x2;
class PylonMissile_Missile_AMRAAM_D_x1;
class PylonMissile_Missile_AMRAAM_D_INT_x1;
class PylonRack_Missile_AMRAAM_D_x1;
class PylonRack_Missile_AMRAAM_D_x2;

class 4Rnd_GAA_missiles;
class PylonRack_1Rnd_GAA_missiles;
class PylonMissile_1Rnd_GAA_missiles;

class GVAR(a): 4Rnd_GAA_missiles {
author = "Dani (TCVM)";
displayName = CSTRING(a);
ammo = QGVAR(a);
};

class GVAR(PylonRack_1Rnd_a): PylonRack_1Rnd_GAA_missiles {
author = "Dani (TCVM)";
displayName = CSTRING(a_1x);
ammo = QGVAR(a);
pylonWeapon = QGVAR(aim120Launcher);
};

class GVAR(PylonMissile_1Rnd_a): PylonMissile_1Rnd_GAA_missiles {
author = "Dani (TCVM)";
displayName = CSTRING(a_1x);
ammo = QGVAR(a);
pylonWeapon = QGVAR(aim120Launcher);
};

// AIM-120
class GVAR(c): magazine_Missile_AMRAAM_C_x1 {
author = "Dani (TCVM)";
displayName = CSTRING(c_1x);
ammo = QGVAR(c);
};
class GVAR(PylonMissile_Missile_c_x1): PylonMissile_Missile_AMRAAM_C_x1 {
author = "Dani (TCVM)";
displayName = CSTRING(c_1x);
ammo = QGVAR(c);
pylonWeapon = QGVAR(aim120Launcher);
};
class GVAR(PylonRack_Missile_c_x1): PylonRack_Missile_AMRAAM_C_x1 {
author = "Dani (TCVM)";
displayName = CSTRING(c_1x);
ammo = QGVAR(c);
pylonWeapon = QGVAR(aim120Launcher);
};
class GVAR(PylonRack_Missile_c_x2): PylonRack_Missile_AMRAAM_C_x2 {
author = "Dani (TCVM)";
displayName = CSTRING(c_2x);
ammo = QGVAR(c);
pylonWeapon = QGVAR(aim120Launcher);
};

class GVAR(PylonMissile_Missile_d_x1): PylonMissile_Missile_AMRAAM_D_x1 {
author = "Dani (TCVM)";
displayName = CSTRING(d_1x);
ammo = QGVAR(d);
pylonWeapon = QGVAR(aim120Launcher);
};
class GVAR(PylonMissile_Missile_d_INT_x1): PylonMissile_Missile_AMRAAM_D_INT_x1 {
author = "Dani (TCVM)";
displayName = CSTRING(d_1x);
ammo = QGVAR(d);
pylonWeapon = QGVAR(aim120Launcher);
};
class GVAR(PylonRack_Missile_d_x1): PylonRack_Missile_AMRAAM_D_x1 {
author = "Dani (TCVM)";
displayName = CSTRING(d_1x);
ammo = QGVAR(d);
pylonWeapon = QGVAR(aim120Launcher);
};
class GVAR(PylonRack_Missile_d_x2): PylonRack_Missile_AMRAAM_D_x2 {
author = "Dani (TCVM)";
displayName = CSTRING(d_2x);
ammo = QGVAR(d);
pylonWeapon = QGVAR(aim120Launcher);
};

// R-77
class magazine_Missile_AA_R77_x1;
class PylonMissile_Missile_AA_R77_x1;
class PylonMissile_Missile_AA_R77_INT_x1;

class GVAR(r77): magazine_Missile_AA_R77_x1 {
author = "Dani (TCVM)";
displayName = CSTRING(r77_1x);
ammo = QGVAR(r77);
};
class GVAR(PylonMissile_Missile_R77_x1): PylonMissile_Missile_AA_R77_x1 {
author = "Dani (TCVM)";
displayName = CSTRING(r77_1x);
ammo = QGVAR(r77);
pylonWeapon = QGVAR(r77Launcher);
};
class GVAR(PylonMissile_Missile_R77__INT_x1): PylonMissile_Missile_AA_R77_INT_x1 {
author = "Dani (TCVM)";
displayName = CSTRING(r77_1x);
ammo = QGVAR(r77);
pylonWeapon = QGVAR(r77Launcher);
};
};

118 changes: 118 additions & 0 deletions addons/missile_aim120/CfgWeapons.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,118 @@
class CfgWeapons {
class weapon_AMRAAMLauncher;
class MissileLauncher;

class GVAR(aim120Launcher): weapon_AMRAAMLauncher {
author = "Dani (TCVM)";
displayName = CSTRING(aim120);
weaponLockDelay = 0.5;

magazines[] = {
QGVAR(a),
QGVAR(PylonRack_1Rnd_a),
QGVAR(PylonMissile_1Rnd_a),

QGVAR(c),
QGVAR(PylonMissile_Missile_c_x1),
QGVAR(PylonRack_Missile_c_x1),
QGVAR(PylonRack_Missile_c_x2),

QGVAR(PylonMissile_Missile_d_x1),
QGVAR(PylonMissile_Missile_d_INT_x1),
QGVAR(PylonRack_Missile_d_x1),
QGVAR(PylonRack_Missile_d_x2)
};

modes[] = {"Direct", "Loft"};
class Direct: MissileLauncher {
displayName = CSTRING(direct);
textureType = "direct";
reloadTime = 0.1;
magazineReloadTime = 0.1;
aiRateOfFire = 15;
aiRateOfFireDispersion = -10;
aiRateOfFireDistance = 10000;
minRange = 800;
minRangeProbab = 0.5;
midRange = 2500;
midRangeProbab = 0.95;
maxRange = 4000;
maxRangeProbab = 1;
sounds[] = {"StandardSound"};
class StandardSound {
begin1[] = {"A3\Sounds_F\weapons\Rockets\missile_2", 1.12202, 1.3, 1000};
soundBegin[] = {"begin1", 1};
weaponSoundEffect = "DefaultRifle";
};
soundFly[] = {"A3\Sounds_F\weapons\Rockets\rocket_fly_1", 1, 1.5, 700};
lockingTargetSound[] = {"\A3\Sounds_F\weapons\Rockets\locked_1", 0.562341, 1};
lockedTargetSound[] = {"\A3\Sounds_F\weapons\Rockets\locked_3", 0.562341, 2.5};

EGVAR(missileGuidance,attackProfile) = "DIR";
};
class Loft: Direct {
displayName = CSTRING(loft);
textureType = "topdown";

minRange = 4000;
minRangeProbab = 0.5;
midRange = 7000;
midRangeProbab = 0.95;
maxRange = 13000;
maxRangeProbab = 1;

EGVAR(missileGuidance,attackProfile) = "LOFT";
};
};

class weapon_R77Launcher;
class GVAR(r77Launcher): weapon_R77Launcher {
author = "Dani (TCVM)";
displayName = CSTRING(r77);
weaponLockDelay = 0.5;

magazines[] = {QGVAR(r77), QGVAR(PylonMissile_Missile_R77_x1), QGVAR(PylonMissile_Missile_R77__INT_x1)};

modes[] = {"Direct", "Loft"};
class Direct: MissileLauncher {
displayName = CSTRING(direct);
textureType = "direct";
reloadTime = 0.1;
magazineReloadTime = 0.1;
aiRateOfFire = 15;
aiRateOfFireDispersion = -10;
aiRateOfFireDistance = 10000;
minRange = 800;
minRangeProbab = 0.5;
midRange = 2500;
midRangeProbab = 0.95;
maxRange = 4000;
maxRangeProbab = 1;
sounds[] = {"StandardSound"};
class StandardSound {
begin1[] = {"A3\Sounds_F\weapons\Rockets\missile_2", 1.12202, 1.3, 1000};
soundBegin[] = {"begin1", 1};
weaponSoundEffect = "DefaultRifle";
};
soundFly[] = {"A3\Sounds_F\weapons\Rockets\rocket_fly_1", 1, 1.5, 700};
lockingTargetSound[] = {"\A3\Sounds_F\weapons\Rockets\locked_1", 0.562341, 1};
lockedTargetSound[] = {"\A3\Sounds_F\weapons\Rockets\locked_3", 0.562341, 2.5};

EGVAR(missileGuidance,attackProfile) = "DIR";
};
class Loft: Direct {
displayName = CSTRING(loft);
textureType = "topdown";

minRange = 4000;
minRangeProbab = 0.5;
midRange = 7000;
midRangeProbab = 0.95;
maxRange = 13000;
maxRangeProbab = 1;

EGVAR(missileGuidance,attackProfile) = "LOFT";
};
};
};

4 changes: 4 additions & 0 deletions addons/missile_aim120/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
ace_missile_aim120
===================

Adds AIM-120, AIM-132, and R-77 AHR missiles
20 changes: 20 additions & 0 deletions addons/missile_aim120/config.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
#include "script_component.hpp"

class CfgPatches {
class ADDON {
name = COMPONENT_NAME;
units[] = {};
weapons[] = {};
requiredVersion = REQUIRED_VERSION;
requiredAddons[] = {"ace_common","ace_missileguidance"};
author = ECSTRING(common,ACETeam);
authors[] = {"Dani (TCVM)"};
url = ECSTRING(main,URL);
VERSION_CONFIG;
};
};

#include "CfgAmmo.hpp"
#include "CfgMagazines.hpp"
#include "CfgWeapons.hpp"

18 changes: 18 additions & 0 deletions addons/missile_aim120/script_component.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
#define COMPONENT missile_aim120
#define COMPONENT_BEAUTIFIED AIM-120
#include "\z\ace\addons\main\script_mod.hpp"

// #define DEBUG_MODE_FULL
// #define DISABLE_COMPILE_CACHE
// #define ENABLE_PERFORMANCE_COUNTERS

#ifdef DEBUG_ENABLED_MISSILE_AIM120
#define DEBUG_MODE_FULL
#endif

#ifdef DEBUG_SETTINGS_MISSILE_AIM120
#define DEBUG_SETTINGS DEBUG_SETTINGS_MISSILE_AIM120
#endif

#include "\z\ace\addons\main\script_macros.hpp"

44 changes: 44 additions & 0 deletions addons/missile_aim120/stringtable.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
<?xml version="1.0" encoding="utf-8"?>
<Project name="ACE">
<Package name="MISSILE_AIM120">
<Key ID="STR_ACE_MISSILE_AIM120_a">
<English>AIM-120A [ACE]</English>
</Key>
<Key ID="STR_ACE_MISSILE_AIM120_a_1x">
<English>1x AIM-120A [ACE]</English>
</Key>
<Key ID="STR_ACE_MISSILE_AIM120_aim120">
<English>AIM-120 [ACE]</English>
</Key>
<Key ID="STR_ACE_MISSILE_AIM120_c">
<English>AIM-120C [ACE]</English>
</Key>
<Key ID="STR_ACE_MISSILE_AIM120_c_1x">
<English>1x AIM-120C [ACE]</English>
</Key>
<Key ID="STR_ACE_MISSILE_AIM120_c_2x">
<English>2x AIM-120C [ACE]</English>
</Key>
<Key ID="STR_ACE_MISSILE_AIM120_d">
<English>AIM-120D [ACE]</English>
</Key>
<Key ID="STR_ACE_MISSILE_AIM120_d_1x">
<English>1x AIM-120D [ACE]</English>
</Key>
<Key ID="STR_ACE_MISSILE_AIM120_d_2x">
<English>2x AIM-120D [ACE]</English>
</Key>
<Key ID="STR_ACE_MISSILE_AIM120_direct">
<English>Direct</English>
</Key>
<Key ID="STR_ACE_MISSILE_AIM120_loft">
<English>Loft</English>
</Key>
<Key ID="STR_ACE_MISSILE_AIM120_r77">
<English>R-77 [ACE]</English>
</Key>
<Key ID="STR_ACE_MISSILE_AIM120_r77_1x">
<English>1x R-77 [ACE]</English>
</Key>
</Package>
</Project>
Loading

0 comments on commit 78f7451

Please sign in to comment.