summaryrefslogtreecommitdiff
path: root/synth/note_skel.cpp
blob: 4f012ed1f8a48b87886f5e2cc294dc2c0701f8f7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
/*
    Copyright (C) 2010-2012 Florian Jung
     
    This file is part of flo's FM synth.

    flo's FM synth is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    flo's FM synth is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with flo's FM synth.  If not, see <http://www.gnu.org/licenses/>.
*/


#include <cmath>

#include "note_skel.h"
#include "globals.h"
#include "defines.h"

using namespace std;

NoteSkel::NoteSkel()
{	
}

NoteSkel::~NoteSkel()
{
	
}

void NoteSkel::set_pitchbend(fixed_t pb)
{
	pitchbend=pb;
	
	recalc_actual_freq();
}

void NoteSkel::set_freq(float f)
{
	old_freq=freq;
	dest_freq=f*ONE;
	portamento_t=0;
	
	do_ksr();
}

void NoteSkel::set_freq(float f, bool do_port)
{
	set_freq(f);
	
	if (!do_port)
		old_freq=dest_freq;
}

void NoteSkel::set_note(int n)
{
	note=n;
	set_freq(440.0*pow(2.0,(float)(n-69)/12.0));
}

void NoteSkel::set_note(int n, bool do_port)
{
	note=n;
	set_freq(440.0*pow(2.0,(float)(n-69)/12.0), do_port);
}

int NoteSkel::get_note()
{
	return note;
}

void NoteSkel::set_vel(float v)
{
	vel=v*ONE;
	
	recalc_factors();
	apply_pfactor();
}

void NoteSkel::set_vol_factor(float vol_fac)
{
	volume_factor=vol_fac;
	
	recalc_factors();
	apply_pfactor();
}

void NoteSkel::set_portamento_frames(jack_nframes_t t)
{
	portamento_frames=t;
	portamento_t=0;
}

int NoteSkel::get_program()
{
	return program;
}