JavaScript:Библиотеки/p5.sound/Класс p5.Envelope/triggerRelease(): различия между версиями
Материал из Онлайн справочника
Перейти к навигацииПерейти к поиску
Myagkij (обсуждение | вклад) Нет описания правки |
Нет описания правки |
||
Строка 14: | Строка 14: | ||
Чтобы использовать эту функцию, нужно подключить библиотеку p5.sound. Для этого в заголовок своего файла «index.html» впишите следующее: | Чтобы использовать эту функцию, нужно подключить библиотеку p5.sound. Для этого в заголовок своего файла «index.html» впишите следующее: | ||
<syntaxhighlight lang="javascript | <syntaxhighlight lang="javascript"> | ||
<script language="javascript" type="text/javascript" src="path/to/p5.sound.js"></script> | <script language="javascript" type="text/javascript" src="path/to/p5.sound.js"></script> | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Строка 20: | Строка 20: | ||
==Синтаксис== | ==Синтаксис== | ||
<syntaxhighlight lang="javascript | <syntaxhighlight lang="javascript"> | ||
triggerRelease(unit, secondsFromNow) | triggerRelease(unit, secondsFromNow) | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Строка 26: | Строка 26: | ||
==Параметры== | ==Параметры== | ||
<syntaxhighlight lang="javascript | <syntaxhighlight lang="javascript"> | ||
unit – объект из библиотеки p5.sound или объект AudioParam из Web Audio API, громкость которого будет управляться с помощью ADSR-огибающей. Тип данных – объект | unit – объект из библиотеки p5.sound или объект AudioParam из Web Audio API, громкость которого будет управляться с помощью ADSR-огибающей. Тип данных – объект | ||
secondsFromNow – время (в секундах) после вызова функции, спустя которое будет включен заданный звуковой объект с ADSR-огибающей. Тип данных – number | secondsFromNow – время (в секундах) после вызова функции, спустя которое будет включен заданный звуковой объект с ADSR-огибающей. Тип данных – number | ||
Строка 33: | Строка 33: | ||
==Возвращаемое значение== | ==Возвращаемое значение== | ||
<syntaxhighlight lang="javascript | <syntaxhighlight lang="javascript"> | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Строка 41: | Строка 41: | ||
===№1=== | ===№1=== | ||
<syntaxhighlight lang="javascript" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS | <syntaxhighlight lang="javascript" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS"> | ||
var attackLevel = 1.0; | var attackLevel = 1.0; | ||
var releaseLevel = 0; | var releaseLevel = 0; | ||
Строка 91: | Строка 91: | ||
===№2=== | ===№2=== | ||
<syntaxhighlight lang="javascript" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS | <syntaxhighlight lang="javascript" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS"> | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Строка 97: | Строка 97: | ||
===№3=== | ===№3=== | ||
<syntaxhighlight lang="javascript" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS | <syntaxhighlight lang="javascript" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS"> | ||
</syntaxhighlight> | </syntaxhighlight> |
Версия от 20:05, 23 мая 2023
Перевод: Максим Кузьмин
Проверка/Оформление/Редактирование: Мякишев Е.А.
Черновик |
triggerRelease() [1]
Описание
Запускает стадию затухания ADSR-огибающей. Действие этой функции аналогично отпусканию клавиши пианино и последующему затуханию звука, которое будет происходить в соответствии со значениями в параметрах, отвечающих за уровень затухания и длительность затухания.
Чтобы использовать эту функцию, нужно подключить библиотеку p5.sound. Для этого в заголовок своего файла «index.html» впишите следующее:
<script language="javascript" type="text/javascript" src="path/to/p5.sound.js"></script>
Синтаксис
triggerRelease(unit, secondsFromNow)
Параметры
unit – объект из библиотеки p5.sound или объект AudioParam из Web Audio API, громкость которого будет управляться с помощью ADSR-огибающей. Тип данных – объект
secondsFromNow – время (в секундах) после вызова функции, спустя которое будет включен заданный звуковой объект с ADSR-огибающей. Тип данных – number
Возвращаемое значение
Пример
№1
var attackLevel = 1.0;
var releaseLevel = 0;
var attackTime = 0.001
var decayTime = 0.3;
var susPercent = 0.4;
var releaseTime = 0.5;
var env, triOsc;
function setup() {
var cnv = createCanvas(100, 100);
background(200);
textAlign(CENTER);
text('click to play', width/2, height/2);
// 'кликните, чтобы начать проигрывание'
env = new p5.Env();
env.setADSR(attackTime, decayTime, susPercent, releaseTime);
env.setRange(attackLevel, releaseLevel);
triOsc = new p5.Oscillator('triangle');
triOsc.amp(env);
triOsc.start();
triOsc.freq(220);
cnv.mousePressed(envAttack);
}
function envAttack(){
console.log('trigger attack');
env.triggerAttack();
background(0,255,0);
text('attack!', width/2, height/2);
// 'атака!'
}
function mouseReleased() {
env.triggerRelease();
background(200);
text('click to play', width/2, height/2);
// 'кликните, чтобы начать проигрывание'
}