annotate libaf/af_karaoke.c @ 33263:5f527a9a9521

Add an exit function. This function will allow performing clean-up operations. (MPlayer calls guiDone() before exiting, but only if the GUI has been initialized, i.e. if guiInit() has been called successfully. Any exit_player()/exit_player_with_rc() after GUI's cfg_read() until guiInit(), or any exit_player() during guiInit() itself will end the GUI without calling guiDone(). This exit function will at least handle abortions during guiInit() itself. It will be called twice in case of an guiExit() after GUI initialization - first directly, next by guiDone() via MPlayer's exit_player_with_rc().)
author ib
date Tue, 03 May 2011 12:19:22 +0000
parents 8fa2f43cb760
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
1 /*
28229
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
2 * simple voice removal filter
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
3 *
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
4 * copyright (c) 2006 Reynaldo H. Verdejo Pinochet
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
5 * Based on code by Alex Beregszaszi for his 'center' filter.
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
6 *
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
7 * This file is part of MPlayer.
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
8 *
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
9 * MPlayer is free software; you can redistribute it and/or modify
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
10 * it under the terms of the GNU General Public License as published by
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
11 * the Free Software Foundation; either version 2 of the License, or
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
12 * (at your option) any later version.
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
13 *
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
14 * MPlayer is distributed in the hope that it will be useful,
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
17 * GNU General Public License for more details.
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
18 *
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
19 * You should have received a copy of the GNU General Public License along
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
20 * with MPlayer; if not, write to the Free Software Foundation, Inc.,
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
21 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
72d0b1444141 Replace informal license notices by standard license header
diego
parents: 24888
diff changeset
22 */
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
23
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
24 #include <stdio.h>
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
25 #include <stdlib.h>
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 28229
diff changeset
26 #include <string.h>
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
27
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
28 #include "af.h"
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
29
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
30 // Data for specific instances of this filter
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
31
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
32 // Initialization and runtime control
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
33 static int control(struct af_instance_s* af, int cmd, void* arg)
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
34 {
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
35 switch(cmd){
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
36 case AF_CONTROL_REINIT:
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
37 af->data->rate = ((af_data_t*)arg)->rate;
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
38 af->data->nch = ((af_data_t*)arg)->nch;
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
39 af->data->format= AF_FORMAT_FLOAT_NE;
19199
ff3ed01e9043 fix wrong and unrelated change done in r19199
reynaldo
parents: 19194
diff changeset
40 af->data->bps = 4;
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
41 return af_test_output(af,(af_data_t*)arg);
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
42 }
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
43 return AF_UNKNOWN;
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
44 }
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
45
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 28229
diff changeset
46 // Deallocate memory
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
47 static void uninit(struct af_instance_s* af)
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
48 {
32537
8fa2f43cb760 Remove most of the NULL pointer check before free all over the code
cboesch
parents: 29263
diff changeset
49 free(af->data);
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
50 }
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
51
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
52 // Filter data through filter
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
53 static af_data_t* play(struct af_instance_s* af, af_data_t* data)
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
54 {
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
55 af_data_t* c = data; // Current working data
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
56 float* a = c->audio; // Audio data
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 28229
diff changeset
57 int len = c->len/4; // Number of samples in current audio block
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
58 int nch = c->nch; // Number of channels
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
59 register int i;
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
60
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 28229
diff changeset
61 /*
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 28229
diff changeset
62 FIXME1 add a low band pass filter to avoid suppressing
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
63 centered bass/drums
18589
de155823ef82 Fix a few minor spelling errors in comments.
corey
parents: 18470
diff changeset
64 FIXME2 better calculated* attenuation factor
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
65 */
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 28229
diff changeset
66
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
67 for(i=0;i<len;i+=nch)
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
68 {
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
69 a[i] = (a[i] - a[i+1]) * 0.7;
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
70 a[i+1]=a[i];
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
71 }
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 28229
diff changeset
72
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
73 return c;
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
74 }
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
75
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
76 // Allocate memory and set function pointers
22746
fd6f824ef894 Rename open to af_open so as not to conflict with a previous header definition.
diego
parents: 19199
diff changeset
77 static int af_open(af_instance_t* af){
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
78 af->control = control;
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
79 af->uninit = uninit;
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
80 af->play = play;
24888
b2402b4f0afa libaf: change filter input/output ratio calculations
uau
parents: 22746
diff changeset
81 af->mul = 1;
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
82 af->data = calloc(1,sizeof(af_data_t));
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
83
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
84 if(af->data == NULL)
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
85 return AF_ERROR;
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 28229
diff changeset
86
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
87 return AF_OK;
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
88 }
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
89
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
90 // Description of this filter
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
91 af_info_t af_info_karaoke = {
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
92 "Simple karaoke/voice-removal audio filter",
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
93 "karaoke",
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
94 "Reynaldo H. Verdejo Pinochet",
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
95 "",
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
96 AF_FLAGS_NOT_REENTRANT,
22746
fd6f824ef894 Rename open to af_open so as not to conflict with a previous header definition.
diego
parents: 19199
diff changeset
97 af_open
18470
0ea3c732d72d New karaoke af
reynaldo
parents:
diff changeset
98 };