Implement SFX block API and bump version
This commit is contained in:
parent
d581ec598a
commit
9e6edc19bd
4 changed files with 219 additions and 2 deletions
|
@ -135,6 +135,14 @@ namespace GamecraftModdingAPI
|
||||||
CommonExclusiveGroups.BUILD_BUILDINGSPAWN_BLOCK_GROUP
|
CommonExclusiveGroups.BUILD_BUILDINGSPAWN_BLOCK_GROUP
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
typeof(SfxBlock),
|
||||||
|
new[]
|
||||||
|
{
|
||||||
|
CommonExclusiveGroups.BUILD_SIMPLESFX_BLOCK_GROUP,
|
||||||
|
CommonExclusiveGroups.BUILD_LOOPEDSFX_BLOCK_GROUP
|
||||||
|
}
|
||||||
|
},
|
||||||
{typeof(TextBlock), new[] {CommonExclusiveGroups.BUILD_TEXT_BLOCK_GROUP}},
|
{typeof(TextBlock), new[] {CommonExclusiveGroups.BUILD_TEXT_BLOCK_GROUP}},
|
||||||
{typeof(Timer), new[] {CommonExclusiveGroups.BUILD_TIMER_BLOCK_GROUP}}
|
{typeof(Timer), new[] {CommonExclusiveGroups.BUILD_TIMER_BLOCK_GROUP}}
|
||||||
};
|
};
|
||||||
|
|
|
@ -97,7 +97,7 @@ namespace GamecraftModdingAPI.Blocks
|
||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
Assert.Log("Block exists: " + Exists);
|
//Assert.Log("Block exists: " + Exists);
|
||||||
return BlockEngine.GetBlockInfo(this,
|
return BlockEngine.GetBlockInfo(this,
|
||||||
(MusicBlockDataEntityStruct msdes) => (ChannelType) msdes.channelType);
|
(MusicBlockDataEntityStruct msdes) => (ChannelType) msdes.channelType);
|
||||||
}
|
}
|
||||||
|
|
209
GamecraftModdingAPI/Blocks/SfxBlock.cs
Normal file
209
GamecraftModdingAPI/Blocks/SfxBlock.cs
Normal file
|
@ -0,0 +1,209 @@
|
||||||
|
using System;
|
||||||
|
using FMOD.Studio;
|
||||||
|
using FMODUnity;
|
||||||
|
using Gamecraft.Wires;
|
||||||
|
using RobocraftX.Blocks;
|
||||||
|
using RobocraftX.Common;
|
||||||
|
using Svelto.ECS;
|
||||||
|
|
||||||
|
namespace GamecraftModdingAPI.Blocks
|
||||||
|
{
|
||||||
|
public class SfxBlock : SignalingBlock
|
||||||
|
{
|
||||||
|
public SfxBlock(EGID id) : base(id)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public SfxBlock(uint id) : base(new EGID(id, CommonExclusiveGroups.BUILD_SIMPLESFX_BLOCK_GROUP /* This could also be BUILD_LOOPEDSFX_BLOCK_GROUP */))
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public float Volume
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return BlockEngine.GetBlockInfo(this, (SoundSfxBlockDataEntityStruct obj) => obj.tweakableVolume);
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
BlockEngine.SetBlockInfo(this,
|
||||||
|
(ref SoundSfxBlockDataEntityStruct obj, float val) => obj.tweakableVolume = val, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public float Pitch
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return BlockEngine.GetBlockInfo(this, (SoundSfxBlockDataEntityStruct obj) => obj.tweakablePitch);
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
BlockEngine.SetBlockInfo(this,
|
||||||
|
(ref SoundSfxBlockDataEntityStruct obj, float val) => obj.tweakablePitch = val, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool Is3D
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return BlockEngine.GetBlockInfo(this, (SoundSfxBlockDataEntityStruct obj) => obj.is3D);
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
BlockEngine.SetBlockInfo(this,
|
||||||
|
(ref SoundSfxBlockDataEntityStruct obj, bool val) => obj.is3D = val, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public ChannelType ChannelType
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return BlockEngine.GetBlockInfo(this, (SoundSfxBlockDataEntityStruct obj) => (ChannelType)obj.channelType);
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
BlockEngine.SetBlockInfo(this,
|
||||||
|
(ref SoundSfxBlockDataEntityStruct obj, ChannelType val) => obj.tweakableVolume = (byte) val, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public byte TrackIndex
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return BlockEngine.GetBlockInfo(this, (SoundSfxBlockDataEntityStruct obj) => obj.soundEffectIndex);
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
BlockEngine.SetBlockInfo(this,
|
||||||
|
(ref SoundSfxBlockDataEntityStruct obj, byte val) => obj.soundEffectIndex = val, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// track
|
||||||
|
public Guid Track
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return BlockEngine.GetBlockInfo(this,
|
||||||
|
(SoundSfxBlockDataEntityStruct obj) => obj.is3D ? obj.fmod3DEventPaths.Get<Guid>(obj.soundEffectIndex) : obj.fmod2DEventPaths.Get<Guid>(obj.soundEffectIndex));
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
BlockEngine.SetBlockInfo(this, (ref SoundSfxBlockDataEntityStruct obj, Guid val) =>
|
||||||
|
{
|
||||||
|
for (byte i = 0; i < obj.fmod2DEventPaths.Count<Guid>(); i++)
|
||||||
|
{
|
||||||
|
Guid track = obj.fmod2DEventPaths.Get<Guid>(i);
|
||||||
|
if (track == val)
|
||||||
|
{
|
||||||
|
obj.soundEffectIndex = i;
|
||||||
|
obj.is3D = false;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (byte i = 0; i < obj.fmod3DEventPaths.Count<Guid>(); i++)
|
||||||
|
{
|
||||||
|
Guid track = obj.fmod3DEventPaths.Get<Guid>(i);
|
||||||
|
if (track == val)
|
||||||
|
{
|
||||||
|
obj.soundEffectIndex = i;
|
||||||
|
obj.is3D = true;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// all tracks
|
||||||
|
public Guid[] Tracks2D
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return BlockEngine.GetBlockInfo(this, (SoundSfxBlockDataEntityStruct obj) =>
|
||||||
|
{
|
||||||
|
Guid[] tracks = new Guid[obj.fmod2DEventPaths.Count<Guid>()];
|
||||||
|
for (byte i = 0; i < tracks.Length; i++)
|
||||||
|
{
|
||||||
|
tracks[i] = obj.fmod2DEventPaths.Get<Guid>(i);
|
||||||
|
}
|
||||||
|
return tracks;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public Guid[] Tracks3D
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return BlockEngine.GetBlockInfo(this, (SoundSfxBlockDataEntityStruct obj) =>
|
||||||
|
{
|
||||||
|
Guid[] tracks = new Guid[obj.fmod3DEventPaths.Count<Guid>()];
|
||||||
|
for (byte i = 0; i < tracks.Length; i++)
|
||||||
|
{
|
||||||
|
tracks[i] = obj.fmod2DEventPaths.Get<Guid>(i);
|
||||||
|
}
|
||||||
|
return tracks;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool IsLooped
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return BlockEngine.GetBlockInfo(this, (SoundSfxBlockDataEntityStruct obj) => obj.isLoopedBlock);
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
BlockEngine.SetBlockInfo(this,
|
||||||
|
(ref SoundSfxBlockDataEntityStruct obj, bool val) => obj.isLoopedBlock = val, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool IsPlaying
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return BlockEngine.GetBlockInfo(this,
|
||||||
|
(SoundSfxBlockDataEntityStruct obj) => obj.isPlaying);
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
BlockEngine.SetBlockInfo(this, (ref SoundSfxBlockDataEntityStruct obj, bool val) =>
|
||||||
|
{
|
||||||
|
if (obj.isPlaying == val) return;
|
||||||
|
if (val)
|
||||||
|
{
|
||||||
|
// start playing
|
||||||
|
EventInstance inst = RuntimeManager.CreateInstance(obj.is3D ? obj.fmod3DEventPaths.Get<Guid>(obj.soundEffectIndex) : obj.fmod2DEventPaths.Get<Guid>(obj.soundEffectIndex));
|
||||||
|
inst.setVolume(obj.tweakableVolume / 100f);
|
||||||
|
inst.start();
|
||||||
|
obj.eventHandle = inst.handle;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// stop playing
|
||||||
|
EventInstance inst = default(EventInstance);
|
||||||
|
inst.handle = obj.eventHandle;
|
||||||
|
inst.stop(FMOD.Studio.STOP_MODE.ALLOWFADEOUT);
|
||||||
|
inst.release();
|
||||||
|
}
|
||||||
|
obj.isPlaying = val;
|
||||||
|
}, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,7 +2,7 @@
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<TargetFramework>net472</TargetFramework>
|
<TargetFramework>net472</TargetFramework>
|
||||||
<AutoGenerateBindingRedirects>true</AutoGenerateBindingRedirects>
|
<AutoGenerateBindingRedirects>true</AutoGenerateBindingRedirects>
|
||||||
<Version>1.5.0-preview</Version>
|
<Version>1.6.0-preview</Version>
|
||||||
<Authors>Exmods</Authors>
|
<Authors>Exmods</Authors>
|
||||||
<PackageLicenseExpression>GNU General Public Licence 3+</PackageLicenseExpression>
|
<PackageLicenseExpression>GNU General Public Licence 3+</PackageLicenseExpression>
|
||||||
<PackageProjectUrl>https://git.exmods.org/modtainers/GamecraftModdingAPI</PackageProjectUrl>
|
<PackageProjectUrl>https://git.exmods.org/modtainers/GamecraftModdingAPI</PackageProjectUrl>
|
||||||
|
|
Loading…
Reference in a new issue