mirror of
https://github.com/FlightControl-Master/MOOSE.git
synced 2025-10-29 16:58:06 +00:00
Merge branch 'FF/MasterDevel' into FF/Ops
This commit is contained in:
commit
7c37d8b204
@ -3408,8 +3408,8 @@ function SPAWN:_SpawnCleanUpScheduler()
|
|||||||
if Stamp.Vec2 then
|
if Stamp.Vec2 then
|
||||||
if SpawnUnit:InAir() == false and SpawnUnit:GetVelocityKMH() < 1 then
|
if SpawnUnit:InAir() == false and SpawnUnit:GetVelocityKMH() < 1 then
|
||||||
local NewVec2 = SpawnUnit:GetVec2()
|
local NewVec2 = SpawnUnit:GetVec2()
|
||||||
if Stamp.Vec2.x == NewVec2.x and Stamp.Vec2.y == NewVec2.y then
|
if (Stamp.Vec2.x == NewVec2.x and Stamp.Vec2.y == NewVec2.y) or (SpawnUnit:GetLife() <= 1) then
|
||||||
-- If the plane is not moving, and is on the ground, assign it with a timestamp...
|
-- If the plane is not moving or dead , and is on the ground, assign it with a timestamp...
|
||||||
if Stamp.Time + self.SpawnCleanUpInterval < timer.getTime() then
|
if Stamp.Time + self.SpawnCleanUpInterval < timer.getTime() then
|
||||||
self:T( { "CleanUp Scheduler:", "ReSpawning:", SpawnGroup:GetName() } )
|
self:T( { "CleanUp Scheduler:", "ReSpawning:", SpawnGroup:GetName() } )
|
||||||
self:ReSpawn( SpawnCursor )
|
self:ReSpawn( SpawnCursor )
|
||||||
@ -3427,7 +3427,7 @@ function SPAWN:_SpawnCleanUpScheduler()
|
|||||||
else
|
else
|
||||||
if SpawnUnit:InAir() == false then
|
if SpawnUnit:InAir() == false then
|
||||||
Stamp.Vec2 = SpawnUnit:GetVec2()
|
Stamp.Vec2 = SpawnUnit:GetVec2()
|
||||||
if SpawnUnit:GetVelocityKMH() < 1 then
|
if (SpawnUnit:GetVelocityKMH() < 1) then
|
||||||
Stamp.Time = timer.getTime()
|
Stamp.Time = timer.getTime()
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
|
|||||||
@ -319,12 +319,20 @@ function MSRS:PlaySoundFile(Soundfile, Delay)
|
|||||||
-- Append file.
|
-- Append file.
|
||||||
command=command.." --file="..tostring(soundfile)
|
command=command.." --file="..tostring(soundfile)
|
||||||
|
|
||||||
|
self:_ExecCommand(command)
|
||||||
|
|
||||||
|
--[[
|
||||||
|
|
||||||
|
command=command.." > bla.txt"
|
||||||
|
|
||||||
-- Debug output.
|
-- Debug output.
|
||||||
self:I(string.format("MSRS PlaySoundfile command=%s", command))
|
self:I(string.format("MSRS PlaySoundfile command=%s", command))
|
||||||
|
|
||||||
-- Execute SRS command.
|
-- Execute SRS command.
|
||||||
local x=os.execute(command)
|
local x=os.execute(command)
|
||||||
|
|
||||||
|
]]
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
return self
|
return self
|
||||||
@ -347,11 +355,17 @@ function MSRS:PlaySoundText(SoundText, Delay)
|
|||||||
-- Append text.
|
-- Append text.
|
||||||
command=command..string.format(" --text=\"%s\"", tostring(SoundText.text))
|
command=command..string.format(" --text=\"%s\"", tostring(SoundText.text))
|
||||||
|
|
||||||
|
self:_ExecCommand(command)
|
||||||
|
|
||||||
|
--[[
|
||||||
|
command=command.." > bla.txt"
|
||||||
|
|
||||||
-- Debug putput.
|
-- Debug putput.
|
||||||
self:I(string.format("MSRS PlaySoundfile command=%s", command))
|
self:I(string.format("MSRS PlaySoundfile command=%s", command))
|
||||||
|
|
||||||
-- Execute SRS command.
|
-- Execute SRS command.
|
||||||
local x=os.execute(command)
|
local x=os.execute(command)
|
||||||
|
]]
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -375,6 +389,10 @@ function MSRS:PlayText(Text, Delay)
|
|||||||
-- Append text.
|
-- Append text.
|
||||||
command=command..string.format(" --text=\"%s\"", tostring(Text))
|
command=command..string.format(" --text=\"%s\"", tostring(Text))
|
||||||
|
|
||||||
|
self:_ExecCommand(command)
|
||||||
|
|
||||||
|
--[[
|
||||||
|
|
||||||
-- Check that length of command is max 255 chars or os.execute() will not work!
|
-- Check that length of command is max 255 chars or os.execute() will not work!
|
||||||
if string.len(command)>255 then
|
if string.len(command)>255 then
|
||||||
|
|
||||||
@ -403,7 +421,7 @@ function MSRS:PlayText(Text, Delay)
|
|||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
]]
|
||||||
end
|
end
|
||||||
|
|
||||||
return self
|
return self
|
||||||
@ -441,7 +459,8 @@ function MSRS:PlayTextFile(TextFile, Delay)
|
|||||||
local l=string.len(command)
|
local l=string.len(command)
|
||||||
|
|
||||||
-- Execute SRS command.
|
-- Execute SRS command.
|
||||||
local x=os.execute(command)
|
self:_ExecCommand(command)
|
||||||
|
-- local x=os.execute(command)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -453,6 +472,73 @@ end
|
|||||||
-- Misc Functions
|
-- Misc Functions
|
||||||
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
--- Execute SRS command to play sound using the `DCS-SR-ExternalAudio.exe`.
|
||||||
|
-- @param #MSRS self
|
||||||
|
-- @param #string command Command to executer
|
||||||
|
-- @return #string Command.
|
||||||
|
function MSRS:_ExecCommand(command)
|
||||||
|
|
||||||
|
-- Create a tmp file.
|
||||||
|
local filename = os.getenv('TMP') .. "\\MSRS-"..STTS.uuid()..".bat"
|
||||||
|
|
||||||
|
local script = io.open(filename, "w+")
|
||||||
|
script:write(command.." && exit")
|
||||||
|
script:close()
|
||||||
|
|
||||||
|
-- Play command.
|
||||||
|
command=string.format('start /b "" "%s"', filename)
|
||||||
|
|
||||||
|
if true then
|
||||||
|
|
||||||
|
-- Create a tmp file.
|
||||||
|
local filenvbs = os.getenv('TMP') .. "\\MSRS-"..STTS.uuid()..".vbs"
|
||||||
|
|
||||||
|
-- VBS script
|
||||||
|
local script = io.open(filenvbs, "w+")
|
||||||
|
script:write(string.format('Dim WinScriptHost\n'))
|
||||||
|
script:write(string.format('Set WinScriptHost = CreateObject("WScript.Shell")\n'))
|
||||||
|
script:write(string.format('WinScriptHost.Run Chr(34) & "%s" & Chr(34), 0\n', filename))
|
||||||
|
script:write(string.format('Set WinScriptHost = Nothing'))
|
||||||
|
script:close()
|
||||||
|
|
||||||
|
-- Run visual basic script. This still pops up a window but very briefly and does not put the DCS window out of focus.
|
||||||
|
local runvbs=string.format('cscript.exe //Nologo //B "%s"', filenvbs)
|
||||||
|
|
||||||
|
-- Debug output.
|
||||||
|
self:I("MSRS execute command="..command)
|
||||||
|
self:I("MSRS execute VBS command="..runvbs)
|
||||||
|
|
||||||
|
-- Now create powershell process and feed your script to its stdin
|
||||||
|
--local pipe = io.popen("cscript.exe //Nologo //B", "w")
|
||||||
|
--pipe:write(script)
|
||||||
|
--pipe:close()
|
||||||
|
|
||||||
|
-- Play file in 0.01 seconds
|
||||||
|
os.execute(runvbs)
|
||||||
|
|
||||||
|
-- Remove file in 1 second.
|
||||||
|
timer.scheduleFunction(os.remove, filename, timer.getTime()+1)
|
||||||
|
timer.scheduleFunction(os.remove, filenvbs, timer.getTime()+1)
|
||||||
|
|
||||||
|
|
||||||
|
else
|
||||||
|
|
||||||
|
-- Debug output.
|
||||||
|
self:I("MSRS execute command="..command)
|
||||||
|
|
||||||
|
-- Play file in 0.05 seconds
|
||||||
|
timer.scheduleFunction(os.execute, command, timer.getTime()+0.01)
|
||||||
|
|
||||||
|
-- Remove file in 1 second.
|
||||||
|
timer.scheduleFunction(os.remove, filename, timer.getTime()+1)
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
return res
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
--- Get SRS command to play sound using the `DCS-SR-ExternalAudio.exe`.
|
--- Get SRS command to play sound using the `DCS-SR-ExternalAudio.exe`.
|
||||||
-- @param #MSRS self
|
-- @param #MSRS self
|
||||||
-- @param #table freqs Frequencies in MHz.
|
-- @param #table freqs Frequencies in MHz.
|
||||||
@ -489,6 +575,10 @@ function MSRS:_GetCommand(freqs, modus, coal, gender, voice, culture, volume, sp
|
|||||||
-- Command from orig STTS script. Works better for some unknown reason!
|
-- Command from orig STTS script. Works better for some unknown reason!
|
||||||
local command=string.format("start /min \"\" /d \"%s\" /b \"%s\" -f %s -m %s -c %s -p %s -n \"%s\" -h", path, exe, freqs, modus, coal, port, "ROBOT")
|
local command=string.format("start /min \"\" /d \"%s\" /b \"%s\" -f %s -m %s -c %s -p %s -n \"%s\" -h", path, exe, freqs, modus, coal, port, "ROBOT")
|
||||||
|
|
||||||
|
--local command=string.format('start /b "" /d "%s" "%s" -f %s -m %s -c %s -p %s -n "%s" > bla.txt', path, exe, freqs, modus, coal, port, "ROBOT")
|
||||||
|
|
||||||
|
local command=string.format('%s/%s -f %s -m %s -c %s -p %s -n "%s"', path, exe, freqs, modus, coal, port, "ROBOT")
|
||||||
|
|
||||||
-- Set voice or gender/culture.
|
-- Set voice or gender/culture.
|
||||||
if voice then
|
if voice then
|
||||||
-- Use a specific voice (no need for gender and/or culture.
|
-- Use a specific voice (no need for gender and/or culture.
|
||||||
|
|||||||
@ -202,6 +202,7 @@ function COMMANDCENTER:New( CommandCenterPositionable, CommandCenterName )
|
|||||||
self:SetAutoAcceptTasks( true )
|
self:SetAutoAcceptTasks( true )
|
||||||
self:SetAutoAssignMethod( COMMANDCENTER.AutoAssignMethods.Distance )
|
self:SetAutoAssignMethod( COMMANDCENTER.AutoAssignMethods.Distance )
|
||||||
self:SetFlashStatus( false )
|
self:SetFlashStatus( false )
|
||||||
|
self:SetMessageDuration(10)
|
||||||
|
|
||||||
self:HandleEvent( EVENTS.Birth,
|
self:HandleEvent( EVENTS.Birth,
|
||||||
--- @param #COMMANDCENTER self
|
--- @param #COMMANDCENTER self
|
||||||
@ -682,7 +683,7 @@ end
|
|||||||
-- @param #string Message The message text.
|
-- @param #string Message The message text.
|
||||||
function COMMANDCENTER:MessageToAll( Message )
|
function COMMANDCENTER:MessageToAll( Message )
|
||||||
|
|
||||||
self:GetPositionable():MessageToAll( Message, 20, self:GetName() )
|
self:GetPositionable():MessageToAll( Message, self.MessageDuration, self:GetName() )
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -692,7 +693,7 @@ end
|
|||||||
-- @param Wrapper.Group#GROUP MessageGroup The group to receive the message.
|
-- @param Wrapper.Group#GROUP MessageGroup The group to receive the message.
|
||||||
function COMMANDCENTER:MessageToGroup( Message, MessageGroup )
|
function COMMANDCENTER:MessageToGroup( Message, MessageGroup )
|
||||||
|
|
||||||
self:GetPositionable():MessageToGroup( Message, 15, MessageGroup, self:GetShortText() )
|
self:GetPositionable():MessageToGroup( Message, self.MessageDuration, MessageGroup, self:GetShortText() )
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -715,7 +716,7 @@ function COMMANDCENTER:MessageToCoalition( Message )
|
|||||||
local CCCoalition = self:GetPositionable():GetCoalition()
|
local CCCoalition = self:GetPositionable():GetCoalition()
|
||||||
--TODO: Fix coalition bug!
|
--TODO: Fix coalition bug!
|
||||||
|
|
||||||
self:GetPositionable():MessageToCoalition( Message, 15, CCCoalition, self:GetShortText() )
|
self:GetPositionable():MessageToCoalition( Message, self.MessageDuration, CCCoalition, self:GetShortText() )
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -795,9 +796,18 @@ end
|
|||||||
|
|
||||||
--- Let the command center flash a report of the status of the subscribed task to a group.
|
--- Let the command center flash a report of the status of the subscribed task to a group.
|
||||||
-- @param #COMMANDCENTER self
|
-- @param #COMMANDCENTER self
|
||||||
|
-- @param Flash #boolean
|
||||||
function COMMANDCENTER:SetFlashStatus( Flash )
|
function COMMANDCENTER:SetFlashStatus( Flash )
|
||||||
self:F()
|
self:F()
|
||||||
|
|
||||||
self.FlashStatus = Flash or true
|
self.FlashStatus = Flash and true
|
||||||
|
end
|
||||||
|
|
||||||
|
--- Duration a command center message is shown.
|
||||||
|
-- @param #COMMANDCENTER self
|
||||||
|
-- @param seconds #number
|
||||||
|
function COMMANDCENTER:SetMessageDuration(seconds)
|
||||||
|
self:F()
|
||||||
|
|
||||||
|
self.MessageDuration = 10 or seconds
|
||||||
end
|
end
|
||||||
|
|||||||
@ -1407,7 +1407,8 @@ function AIRBASE:GetRunwayData(magvar, mark)
|
|||||||
name==AIRBASE.PersianGulf.Abu_Dhabi_International_Airport or
|
name==AIRBASE.PersianGulf.Abu_Dhabi_International_Airport or
|
||||||
name==AIRBASE.PersianGulf.Dubai_Intl or
|
name==AIRBASE.PersianGulf.Dubai_Intl or
|
||||||
name==AIRBASE.PersianGulf.Shiraz_International_Airport or
|
name==AIRBASE.PersianGulf.Shiraz_International_Airport or
|
||||||
name==AIRBASE.PersianGulf.Kish_International_Airport then
|
name==AIRBASE.PersianGulf.Kish_International_Airport or
|
||||||
|
name==AIRBASE.MarianaIslands.Andersen then
|
||||||
|
|
||||||
-- 1-->4, 2-->3, 3-->2, 4-->1
|
-- 1-->4, 2-->3, 3-->2, 4-->1
|
||||||
exception=1
|
exception=1
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user