diff projects/tank_wars/render.cpp @ 274:cf98c06c72fd prerelease

merge
author Liam Donovan <l.b.donovan@qmul.ac.uk>
date Tue, 17 May 2016 16:42:02 +0100
parents 8d80eda512cd
children
line wrap: on
line diff
--- a/projects/tank_wars/render.cpp	Tue May 17 16:31:51 2016 +0100
+++ b/projects/tank_wars/render.cpp	Tue May 17 16:42:02 2016 +0100
@@ -68,10 +68,13 @@
 extern int gMusicBufferLength;
 extern float *gSoundBoomBuffer;
 extern int gSoundBoomBufferLength;
+extern float *gSoundHitBuffer;
+extern int gSoundHitBufferLength;
 
 // Current state for sound and music
 int gMusicBufferPointer = 0;	  // 0 means start of buffer...
 int gSoundBoomBufferPointer = -1; // -1 means don't play...
+int gSoundHitBufferPointer = -1;
 float gSoundProjectileOscillatorPhase = 0;
 float gSoundProjectileOscillatorGain = 0.2;
 float gOscillatorPhaseScaler = 0;
@@ -178,6 +181,12 @@
 					gSoundBoomBufferPointer = -1;
 			}
 
+			if(gSoundHitBuffer != 0 && gSoundHitBufferPointer >= 0) {
+				audioSample += gSoundHitBuffer[gSoundHitBufferPointer++];
+				if(gSoundHitBufferPointer >= gSoundHitBufferLength)
+					gSoundHitBufferPointer = -1;
+			}
+
 			// Oscillator plays to indicate projectile height
 			if(gameStatusProjectileInMotion()) {
 				audioSample += gSoundProjectileOscillatorGain * sinf(gSoundProjectileOscillatorPhase);
@@ -237,6 +246,10 @@
 			if(gameStatusCollisionOccurred()) {
 				gSoundBoomBufferPointer = 0;
 			}
+			
+			if(gameStatusTankHitOccurred()) {
+				gSoundHitBufferPointer = 0;
+			}
 		}
 
 		if(gScreenBufferReadPointer >= gScreenBufferReadLength - 1