Processing:Примеры/Расчет вектора: различия между версиями
Материал из Онлайн справочника
Перейти к навигацииПерейти к поиску
Myagkij (обсуждение | вклад) |
Myagkij (обсуждение | вклад) Нет описания правки |
||
(не показаны 2 промежуточные версии 1 участника) | |||
Строка 1: | Строка 1: | ||
{{Processing панель перехода}} | {{Processing панель перехода}} | ||
{{Перевод от Сubewriter}} | {{Перевод от Сubewriter}} | ||
{{Myagkij-редактор}} | {{Myagkij-редактор}} | ||
=Описание<ref>[https://processing.org/examples/vectormath.html processing.org - Vector by Daniel Shiffman.]</ref>= | =Описание<ref>[https://processing.org/examples/vectormath.html processing.org - Vector by Daniel Shiffman.]</ref>= | ||
Строка 54: | Строка 51: | ||
}} | }} | ||
<syntaxhighlight lang="c" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS | <syntaxhighlight lang="c" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS"> | ||
void setup() { | void setup() { | ||
size(640,360); | size(640,360); | ||
Строка 91: | Строка 88: | ||
<references /> | <references /> | ||
{{Навигационная таблица/Портал/Processing}} | |||
{{Навигационная таблица/ | |||
Текущая версия от 08:00, 27 августа 2023
Содержание | Среда разработки Processing | Справочник языка Processing | Библиотеки | Примеры | Режимы программирования |
Перевод: Максим Кузьмин
Проверка/Оформление/Редактирование: Мякишев Е.А.
Описание[1]
Демонстрация применения базовой векторной математики: вычитание, нормализация, увеличение длины вектора. Нормализация – это приведение длины вектора к значению 1.
Пример
void setup() {
size(640,360);
}
void draw() {
background(0);
// вектор, указывающий в сторону курсора мыши:
PVector mouse = new PVector(mouseX,mouseY);
// вектор, указывающий в центр экрана:
PVector center = new PVector(width/2,height/2);
// вычитаем вектор центра из вектора курсора
// и получаем вектор, указывающий от центра к курсору мыши:
mouse.sub(center);
// выполняем нормализацию вектора:
mouse.normalize();
// умножаем нормализованный вектор на 150 (увеличиваем его длину):
mouse.mult(150);
translate(width/2,height/2);
// рисуем получившийся вектор:
stroke(255);
strokeWeight(4);
line(0,0,mouse.x,mouse.y);
}
См.также
Внешние ссылки
Примеры на Processing | |
---|---|
Основы |
|
Продвинутые графические эффекты |
|
Примеры из сторонних библиотек |