9a3d420e1ddaa8c666ba35926ae8652df8ff7891
[terminatorX.git] / src / tX_vtt.h
1 /*
2     terminatorX - realtime audio scratching software
3     Copyright (C) 1999, 2000  Alexander K├Ânig
4  
5     This program is free software; you can redistribute it and/or modify
6     it under the terms of the GNU General Public License as published by
7     the Free Software Foundation; either version 2 of the License, or
8     (at your option) any later version.
9  
10     This program is distributed in the hope that it will be useful,
11     but WITHOUT ANY WARRANTY; without even the implied warranty of
12     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13     GNU General Public License for more details.
14  
15     You should have received a copy of the GNU General Public License
16     along with this program; if not, write to the Free Software
17     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18  
19     File: tX_vtt.h
20  
21     Description: Header to tX_vtt.cc
22     
23     08 Dec 1999 - added audiofile support
24 */    
25
26 #ifndef _h_tx_vtt
27 #define _h_tx_vtt 1
28
29 #include <config.h>
30
31 #ifdef DONT_USE_FLASH
32 #undef USE_FLASH
33 #else
34 #define USE_FLASH 1
35 #endif
36
37 #include <list>
38 #include "tX_types.h"
39 #include "tX_vttgui.h"
40 #include <pthread.h>
41 #include <float.h>
42 #include <stdio.h>
43 #include "tX_audiofile.h"
44 #include "tX_seqpar.h"
45 #include "tX_vttfx.h"
46 #include "tX_ladspa.h"
47
48 #ifdef USE_3DNOW
49 #include "3dnow.h"
50 #endif
51
52 #define EC_MAX_BUFFER 256000
53
54 #define CONTROL_NOTHING 0
55 #define CONTROL_SCRATCH 1
56 #define CONTROL_VOLUME 2
57 #define CONTROL_CUTOFF 3
58 #define CONTROL_FEEDBACK 4
59
60 #define NEED_FADE_OUT 0
61 #define NEED_FADE_IN 1
62
63 #define SAMPLE_MAX    32760.0
64 #define SAMPLE_BORDER 30000.0
65
66
67 class vtt_class
68 {
69         public:
70         /* class vars */
71         static int vtt_amount;
72         static list <vtt_class *> main_list;
73         static list <vtt_class *> render_list;
74
75         static f_prec *mix_buffer;
76         static f_prec *mix_buffer_end;
77         
78         static int16_t *mix_out_buffer;
79         static f_prec mix_max_l;
80         static f_prec mix_max_r;
81         static int samples_in_mix_buffer;
82         static pthread_mutex_t render_lock;
83         
84         static f_prec master_volume;
85         static f_prec res_master_volume;
86         static f_prec vol_channel_adjust;
87
88         static f_prec saturate_fac;
89         static int do_saturate; 
90         
91         static vtt_class * sync_master;
92         static int master_triggered;
93         static int master_triggered_at;
94         static vtt_class * focused_vtt;
95         static int solo_ctr;
96         
97         /* the gui */
98         vtt_gui gui;
99         int have_gui;
100         
101         /* main object vars */
102         char name[256]; // Turntable's name
103         char filename[PATH_MAX]; // The corresponding audiofile
104         
105         int is_playing;
106         int is_sync_master;
107         int is_sync_client;
108         int sync_cycles;
109         int sync_countdown;
110         int want_stop;
111         int sense_cycles;
112         
113         /* builtin fx */
114         vtt_fx* lp_fx;
115         vtt_fx* ec_fx;
116
117 #ifdef USE_FLASH
118         f_prec max_value;
119 #endif
120         
121         int16_t *buffer;        // Actual audio data
122         int samples_in_buffer;  // No. of samples in audio data
123         int do_scratch;
124         
125         f_prec *output_buffer; 
126         f_prec *end_of_outputbuffer;
127         f_prec samples_in_outputbuffer;
128         f_prec inv_samples_in_outputbuffer;
129         
130         /* main playback vars */
131         f_prec rel_volume; // The (user-selected) relative volume
132         f_prec res_volume; // The resulting volume
133 #ifdef USE_3DNOW
134         mmx_t mm_res_volume;
135 #endif  
136         f_prec rel_pitch; // The (user-selected) relative pitch
137         f_prec res_pitch;
138         
139         
140         f_prec pan; // The logical pan value -1 left, 0 center, 1 right
141         f_prec res_volume_left;
142         f_prec res_volume_right;
143         
144         int autotrigger;
145         int loop;
146         
147         d_prec speed;
148         d_prec speed_real;
149         d_prec speed_target;
150         d_prec speed_step;
151         d_prec speed_last;
152         int fade_in;
153         int fade_out;
154         int do_mute;
155                 
156         d_prec pos_f;
157         unsigned int pos_i;
158         d_prec maxpos;
159         
160         int mute;
161         int res_mute;
162         int res_mute_old;
163         
164         int mix_mute;
165         int mix_solo;
166         int fade;
167         
168         /* input control vars */
169         int x_control;
170         int y_control;
171
172         /* seq par mapping for x/y axis */
173         tX_seqpar *x_par;
174         tX_seqpar *y_par;
175         
176         /* lp vars */
177         int lp_enable;
178         f_prec lp_gain;
179         f_prec lp_reso;
180         f_prec lp_freq;
181         
182         f_prec lp_buf0;
183         f_prec lp_buf1;
184         f_prec lp_a;
185         f_prec lp_b;
186         f_prec lp_last;
187         f_prec lp_autogain;
188         f_prec lp_resgain;
189         
190         /* echo vars */
191         f_prec ec_buffer[EC_MAX_BUFFER];
192         f_prec *ec_output_buffer;
193         f_prec *ec_delay;
194         f_prec *ec_ptr;
195         int ec_enable;
196         f_prec ec_length;
197         f_prec ec_res_length;
198         f_prec ec_feedback;
199         f_prec ec_pan;
200         f_prec ec_volume;
201         f_prec ec_volume_left;
202         f_prec ec_volume_right;
203         
204         /* sequenceable parameters */
205         tX_seqpar_vtt_speed sp_speed;
206         tX_seqpar_vtt_volume sp_volume;
207         tX_seqpar_vtt_pitch sp_pitch;
208         tX_seqpar_vtt_pan sp_pan;
209         tX_seqpar_vtt_trigger sp_trigger;
210         tX_seqpar_vtt_loop sp_loop;
211         tX_seqpar_vtt_sync_client sp_sync_client;
212         tX_seqpar_vtt_sync_cycles sp_sync_cycles;
213         tX_seqpar_vtt_lp_enable sp_lp_enable;
214         tX_seqpar_vtt_lp_gain sp_lp_gain;
215         tX_seqpar_vtt_lp_reso sp_lp_reso;
216         tX_seqpar_vtt_lp_freq sp_lp_freq;
217         tX_seqpar_vtt_ec_enable sp_ec_enable;
218         tX_seqpar_vtt_ec_length sp_ec_length;
219         tX_seqpar_vtt_ec_feedback sp_ec_feedback;
220         tX_seqpar_vtt_ec_pan sp_ec_pan;
221         tX_seqpar_vtt_ec_volume sp_ec_volume;
222         tX_seqpar_vtt_mute sp_mute;
223         tX_seqpar_spin sp_spin;
224
225         tx_audiofile *audiofile;
226
227         list <vtt_fx *> fx_list;
228                 
229         public:
230         /* Methods */           
231         vtt_class(int);
232         ~vtt_class();
233         
234         /* Parameter setup methods */
235         void set_name(char *);
236         int set_output_buffer_size(int);
237
238         void set_volume(f_prec);
239         void recalc_volume();
240         
241         void set_pan(f_prec);
242         
243         void set_pitch(f_prec);
244         void recalc_pitch();
245         
246         void set_autotrigger(int);
247         void set_loop(int);
248         
249         void set_mute(int);
250         
251         void set_controls(int, int);
252         void set_y_input_parameter(tX_seqpar *);
253         void set_x_input_parameter(tX_seqpar *);
254         
255         void lp_reset();
256         void lp_set_enable(int);
257         void lp_set_gain(f_prec);
258         void lp_set_reso(f_prec);
259         void lp_set_freq(f_prec);
260         void lp_setup(f_prec, f_prec, f_prec);
261         
262         void ec_set_enable(int);
263         void ec_set_length(f_prec);     
264         void ec_set_feedback(f_prec);
265         void ec_set_volume(f_prec);
266         void ec_set_pan(f_prec);
267         void ec_clear_buffer();
268         
269         void set_sync_master(int);              
270         void set_sync_client(int, int);
271         void set_sync_client_ug(int, int); // and update gui
272         
273         void set_scratch(int);
274         void xy_input(f_prec, f_prec);
275         void handle_input(int, f_prec);
276
277         vtt_fx_ladspa * add_effect(LADSPA_Plugin *);
278         
279         void calc_speed();
280         void render();
281         void forward_turntable();       
282         
283         static int16_t *render_all_turntables();
284         static void forward_all_turntables();
285         
286         static int set_mix_buffer_size(int);
287         static void set_master_volume(f_prec);
288         static void set_master_pitch(f_prec);
289         static void enable_saturate(int);
290         static void focus_no(int);
291         static void focus_next();
292         static void unfocus();  
293         int trigger();
294         
295         int stop();
296         int stop_nolock();
297         
298         int save(FILE *);
299         int load_10(FILE *);
300         int load_11(FILE *);
301         int load_12(FILE *);
302         int load_13(FILE *);
303         
304         static int load_all_10(FILE *, char *fname); /* fname is for display only*/
305         static int load_all_11(FILE *, char *fname); /* fname is for display only*/
306         static int load_all_12(FILE *, char *fname); /* fname is for display only*/
307         static int load_all_13(FILE *, char *fname); /* fname is for display only*/
308         static int save_all(FILE *);
309         int load_file(char *name);      
310
311         void render_scratch();
312         void render_lp();
313         void render_ec();
314         
315         void effect_up(vtt_fx *effect);
316         void effect_down(vtt_fx *effect);
317         void effect_remove(vtt_fx_ladspa *effect);
318         
319         void set_mix_mute(int newstate);
320         void set_mix_solo(int newstate);
321 };
322
323 #endif