Skip to content

Latest commit

 

History

History
146 lines (112 loc) · 3.82 KB

effect_stereoreverse.c

File metadata and controls

146 lines (112 loc) · 3.82 KB
 
Dec 31, 2011
Dec 31, 2011
2
SDL_mixer: An audio mixer library based on the SDL library
Mar 1, 2018
Mar 1, 2018
3
Copyright (C) 1997-2018 Sam Lantinga <slouken@libsdl.org>
Dec 31, 2011
Dec 31, 2011
5
6
7
This software is provided 'as-is', without any express or implied
warranty. In no event will the authors be held liable for any damages
arising from the use of this software.
Dec 31, 2011
Dec 31, 2011
9
10
11
Permission is granted to anyone to use this software for any purpose,
including commercial applications, and to alter it and redistribute it
freely, subject to the following restrictions:
Dec 31, 2011
Dec 31, 2011
13
14
15
16
17
18
19
1. The origin of this software must not be misrepresented; you must not
claim that you wrote the original software. If you use this software
in a product, an acknowledgment in the product documentation would be
appreciated but is not required.
2. Altered source versions must be plainly marked as such, and must not be
misrepresented as being the original software.
3. This notice may not be removed or altered from any source distribution.
Dec 31, 2011
Dec 31, 2011
21
This file by Ryan C. Gordon (icculus@icculus.org)
Dec 31, 2011
Dec 31, 2011
23
24
These are some internally supported special effects that use SDL_mixer's
effect callback API. They are meant for speed over quality. :)
25
26
27
28
29
30
*/
/* $Id$ */
#include <stdio.h>
#include <stdlib.h>
Sep 11, 2001
Sep 11, 2001
31
32
33
34
35
36
37
38
39
40
41
42
#include "SDL.h"
#include "SDL_mixer.h"
#define __MIX_INTERNAL_EFFECT__
#include "effects_internal.h"
/* profile code:
#include <sys/time.h>
#include <unistd.h>
struct timeval tv1;
struct timeval tv2;
May 22, 2013
May 22, 2013
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
gettimeofday(&tv1, NULL);
... do your thing here ...
gettimeofday(&tv2, NULL);
printf("%ld\n", tv2.tv_usec - tv1.tv_usec);
*/
/*
* Stereo reversal effect...this one's pretty straightforward...
*/
Oct 21, 2017
Oct 21, 2017
58
static void SDLCALL _Eff_reversestereo32(int chan, void *stream, int len, void *udata)
Sep 9, 2017
Sep 9, 2017
59
60
61
{
/* 16 bits * 2 channels. */
Uint32 *ptr = (Uint32 *) stream;
Oct 21, 2017
Oct 21, 2017
62
Uint32 tmp;
Sep 9, 2017
Sep 9, 2017
63
64
65
int i;
for (i = 0; i < len; i += 2 * sizeof (Uint32), ptr += 2) {
Oct 21, 2017
Oct 21, 2017
66
67
68
tmp = ptr[0];
ptr[0] = ptr[1];
ptr[1] = tmp;
Sep 9, 2017
Sep 9, 2017
69
70
71
72
}
}
Oct 21, 2017
Oct 21, 2017
73
static void SDLCALL _Eff_reversestereo16(int chan, void *stream, int len, void *udata)
74
75
76
77
78
79
80
81
82
83
84
{
/* 16 bits * 2 channels. */
Uint32 *ptr = (Uint32 *) stream;
int i;
for (i = 0; i < len; i += sizeof (Uint32), ptr++) {
*ptr = (((*ptr) & 0xFFFF0000) >> 16) | (((*ptr) & 0x0000FFFF) << 16);
}
}
Oct 21, 2017
Oct 21, 2017
85
static void SDLCALL _Eff_reversestereo8(int chan, void *stream, int len, void *udata)
86
87
88
89
90
91
92
93
{
/* 8 bits * 2 channels. */
Uint32 *ptr = (Uint32 *) stream;
int i;
/* get the last two bytes if len is not divisible by four... */
if (len % sizeof (Uint32) != 0) {
Uint16 *p = (Uint16 *) (((Uint8 *) stream) + (len - 2));
May 11, 2006
May 11, 2006
94
*p = (Uint16)((((*p) & 0xFF00) >> 8) | (((*ptr) & 0x00FF) << 8));
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
len -= 2;
}
for (i = 0; i < len; i += sizeof (Uint32), ptr++) {
*ptr = (((*ptr) & 0x0000FF00) >> 8) | (((*ptr) & 0x000000FF) << 8) |
(((*ptr) & 0xFF000000) >> 8) | (((*ptr) & 0x00FF0000) << 8);
}
}
int Mix_SetReverseStereo(int channel, int flip)
{
Mix_EffectFunc_t f = NULL;
int channels;
Uint16 format;
Mix_QuerySpec(NULL, &format, &channels);
if (channels == 2) {
Oct 21, 2017
Oct 21, 2017
114
115
116
int bits = (format & 0xFF);
switch (bits) {
case 8:
117
f = _Eff_reversestereo8;
Oct 21, 2017
Oct 21, 2017
118
119
break;
case 16:
Sep 9, 2017
Sep 9, 2017
120
f = _Eff_reversestereo16;
Oct 21, 2017
Oct 21, 2017
121
122
break;
case 32:
Sep 9, 2017
Sep 9, 2017
123
f = _Eff_reversestereo32;
Oct 21, 2017
Oct 21, 2017
124
125
break;
default:
126
127
128
129
130
131
132
133
134
Mix_SetError("Unsupported audio format");
return(0);
}
if (!flip) {
return(Mix_UnregisterEffect(channel, f));
} else {
return(Mix_RegisterEffect(channel, f, NULL, NULL));
}
Sep 9, 2017
Sep 9, 2017
135
} else {
Oct 21, 2017
Oct 21, 2017
136
137
138
Mix_SetError("Trying to reverse stereo on a non-stereo stream");
return(0);
}
139
140
141
142
143
144
145
return(1);
}
/* end of effect_stereoreverse.c ... */
Oct 17, 2017
Oct 17, 2017
146
/* vi: set ts=4 sw=4 expandtab: */