-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathREADME.txt
205 lines (142 loc) · 7.87 KB
/
README.txt
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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
//------------------------------------------------------------------------------
//
// BORDERLANDS: An interactive granular sampler.
// Version 0.04
//------------------------------------------------------------------------------
// Project website:
// http::/ccrma.stanford.edu/~carlsonc/256a/Borderlands/index.html
//
//
// Copyright (C) 2011 Christopher Carlson
// www.modulationindex.com
//
// These install instructions were last updated on Monday, May 26, 2014
// This program 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, version 3.
//
// This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
Thank you for downloading Borderlands!
//------------------------------------------------------------------------
// Release Notes:
//------------------------------------------------------------------------
Version 0.04
-Independent volume control for clouds in dB, controlled by b key (with number entry or shift modification as described in usage instructions)
-Full screen/windowed toggle mode - press o key
-Bug fix - selected grain duration was not being applied to newly added grains (due to missing break in a switch statementÉ)
Version 0.03
-Multichannel support - change MY_CHANNELS in theglobals.h to use > 2 channels, use T key to switch between spatialization modes
-Playback rate LFO frequency control - K key
-Playback rate LFO amount control - L key
Version 0.02
-Linux compatible version released.
-Extraneous files removed from the distribution.
-Some platforms may have problems displaying the grains - they may appear as squares
instead of circles. This is due to lack of support for GL_POINT_SMOOTH on the
user's graphics card. A version that uses gluDisc to render the grains is
available at the project site. It is lower quality, but it worksÉ Squares are nice too...
Version 0.01
-First version, produced for Music 256a at Stanford. OSX only.
//------------------------------------------------------------------------
// Installation:
//------------------------------------------------------------------------
Borderlands has only been tested on OSX 10.6.8.
Please make sure the following libraries are installed on your system.
Libsndfile is used for loading .aiff and .wav files
http://www.mega-nerd.com/libsndfile/
NOTE: When installing libsndfile, make sure you use the following command. The current documentation for libsndfile is not clear
in this regard.
./configure && make && sudo make install
"sudo" is necessary to give you root privileges for the install.
NOTE: On OSX, I would recommend using Homebrew (http://brew.sh/) to install libsndfile (rather than installing manually as described above). Homebrew makes the process much easier:
To install home-brew, paste this into Terminal and hit enter:
ruby -e "$(curl -fsSL https://raw.github.com/Homebrew/homebrew/go/install)"
Once Homebrew is installed, type:
brew install libsndfile
If libsndfile installs correctly, continue installing Borderlands as described below. If the libsndfile install wonÕt run (or requires admin privileges, try
sudo brew install libsndfile
Once libsndfile has successfully installed, navigate to the Borderlands_v0X/Borderlands directory in Terminal, and type make.
Note - if you donÕt understand what is meant by Ònavigate to the Borderlands directory,Ó follow these steps (if you are on a Mac):
-Open Terminal
-Type cd and add a space
-Open the Borderlands_v04 directory in Finder
-Drag the Borderlands folder into the Terminal window next to cd (should now look like cd Users/you/blah/etc/Borderlands_v04/Borderlands).
-Hit enter to change directories.
-Now type make and press enter. Borderlands should start compiling.
If all goes well, the source should compile. You may see a number of warnings about glut functions being deprecated if you are on Mavericks. Please ignore these unless you get any errors that prevent compiling from completing. If you see errors, please email me at carlsonc AT ccrma DOT stanford DOT edu and I will try to help resolve any issues quickly!
//------------------------------------------------------------------------
// Before runningÉ
//------------------------------------------------------------------------
Put your favorite .wav and .aif files into the loops directory contained in the distribution.
These will be automatically loaded when you launch Borderlands.
//------------------------------------------------------------------------
// To launch the softwareÉ
//------------------------------------------------------------------------
Type ./Borderlands from the source directory in terminal. The screen will be black for
a bit while your audio files load, and then you will see a title screen with instructions.
//------------------------------------------------------------------------
// Controls
//------------------------------------------------------------------------
The user interaction is primarily mouse and keyboard based. Here are the main controls:
Entry/Exit
------------
ESC Quit
? key Hide/Show Title Screen
o key Toggle fullscreen/windowed modes
Rectangles
------------
Left click Select
Drag Move
TAB key Cycle selection of overlapping rectangles under mouse
R key + drag Resize
F key Flip orientation
Cloud Addition and Selection
------------
G key (+ shift) Add (remove) cloud to/from end of collection
Delete key Remove selected cloud
Left click Select
Drag Move
Cloud Parameters
------------
After selecting a cloud, parameters associated with the granular synthesis can be edited.
Most parameters involve keyboard interfacing. Select the key corresponding to the mode,
then press it again to change the value. In some cases, numeric keys are used to enter
specific values. In parameters associated with grain motion, the mouse is used.
V key (+ shift) Add (remove) voices
A key Toggle cloud on/off
D key (+ shift) Increment (decrement) duration
D key + numbers Enter duration value (ms) - press Enter to accept
S key (+ shift) Increment (decrement) overlap
S key + numbers Enter overlap value - press Enter to accept
Z key (+ shift) Increment (decrement) pitch
Z key + numbers Enter pitch value - press Enter to accept
W key Change window type (HANNING, TRIANGLE, EXPDEC, REXPDEC, SINC, RANDOM)
W key +
1 through 6 Jump to specific window type
F key Switch grain direction (FORWARD, BACKWARD, RANDOM)
R key Enable mouse control of XY extent of grain position randomness
X key Enable mouse control of X extent of grain position randomness
Y key Enable mouse control of Y extent of grain position randomness
T key Switch spatialization modes
L key (+ shift) Adjust playback rate LFO frequency
K key (+ shift) Adjust playback rate LFO amplitude
B key (+ shift) Adjust cloud volume in dB
//------------------------------------------------------------------------
// Acknowledgement
//------------------------------------------------------------------------
Libraries included in Borderlands:
Synthesis Toolkit
https://ccrma.stanford.edu/software/stk/
RtAudio is used for real-time audio I/O
http://www.music.mcgill.ca/~gary/rtaudio/
Thanks to Ge Wang and Jorge Herrera for their guidance through the initial stages
of this project. Thanks to Mike Rotondo his help in my early brainstorming discussions.
Thanks to Tarik Barri for encouraging me to pursue the idea and for suggesting the
use of the second dimension of the sound rectangles!