Processing:Примеры/Трансформация: различия между версиями

Материал из Онлайн справочника
Перейти к навигацииПерейти к поиску
Нет описания правки
 
Нет описания правки
 
(не показаны 2 промежуточные версии 2 участников)
Строка 1: Строка 1:
{{Processing панель перехода}}
{{Processing панель перехода}}
{{Перевод от Сubewriter}}
{{Перевод от Сubewriter}}
{{Myagkij-редактор}}
{{Myagkij-редактор}}
{{Черновик}}


=Описание<ref>[https://processing.org/examples/morph.html processing.org - Morph]</ref>=
=Описание<ref>[https://processing.org/examples/morph.html processing.org - Morph]</ref>=
Строка 114: Строка 111:
}}
}}


<syntaxhighlight lang="c" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS" enclose="div">
<syntaxhighlight lang="c" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS">
// Два объекта «ArrayLists» для хранения вершин двух фигур.
// Два объекта «ArrayLists» для хранения вершин двух фигур.
// Для этого примера нужно, чтобы в обеих фигурах
// Для этого примера нужно, чтобы в обеих фигурах
Строка 214: Строка 211:
<references />
<references />


{{SEO
{{Навигационная таблица/Портал/Processing}}
|Заголовок статьи=Processing: Трансформация / Онлайн справочник - wikihandbk.com
|Ключевые слова=processing,Трансформация ,Трансформация в processing, пример Трансформация, пример Трансформация в processing
|Описание статьи=
|Изображение статьи для Open Graph=
|Адрес страницы для schemaNewsArticle=<nowiki>http://wikihandbk.com/wiki/Processing:Примеры/Трансформация</nowiki>
|Изображение статьи для schemaNewsArticle=<nowiki></nowiki>
|Высота изображения статьи для schemaNewsArticle=
|Ширина изображения статьи для schemaNewsArticle=
|Дата публикации для schemaNewsArticle=2018-07-31
|Автор=Мякишев Е.А.
|Издатель=myagkij
|Логотип издателя для schemaNewsArticle=<nowiki>http://wikihandbk.com/ruwiki/images/6/61/Tech_geek_logo_1x.jpg</nowiki>
|Ширина логотипа издателя для schemaNewsArticle=60
|Высота логотипа издателя для schemaNewsArticle=45
}}
{{Навигационная таблица/Справочник языка Processing}}
{{Навигационная таблица/Processing/Примеры}}

Текущая версия от 07:55, 27 августа 2023

Перевод: Максим Кузьмин
Проверка/Оформление/Редактирование: Мякишев Е.А.


Описание[1]

Трансформация одной фигуры в другую при помощи интерполяции вершин.

Пример

// Два объекта «ArrayLists» для хранения вершин двух фигур.
// Для этого примера нужно, чтобы в обеих фигурах
// было одинаковое количество вершин.
// То есть оба объекта ArrayList должны быть одинакового размера.
ArrayList<PVector> circle = new ArrayList<PVector>();
ArrayList<PVector> square = new ArrayList<PVector>();

// Еще один ArrayList для третьего комплекта вершин,
// который и будет нарисован на экране:
ArrayList<PVector> morph = new ArrayList<PVector>();

// Эта булева переменная будет контролировать, будем ли мы
// на старте программы превращаться из круга в квадрат или наоборот:
boolean state = false;

void setup() {
  size(640, 360);

  // Создаем круг при помощи векторов, направленных от центра:
  for (int angle = 0; angle < 360; angle += 9) {
    // Обратите внимание, что мы не начинаем с «0»,
    // чтобы соответствовать контуру круга: 
    PVector v = PVector.fromAngle(radians(angle-135));
    v.mult(100);
    circle.add(v);
    // Пока мы в «morph», давайте заполним его пустыми PVector:
    morph.add(new PVector());
  }

  // Квадрат – это несколько вершин и прямых линий.
  // Верхняя сторона квадрата:
  for (int x = -50; x < 50; x += 10) {
    square.add(new PVector(x, -50));
  }
  // Правая сторона квадрата:
  for (int y = -50; y < 50; y += 10) {
    square.add(new PVector(50, y));
  }
  // Нижняя сторона квадрата:
  for (int x = 50; x > -50; x -= 10) {
    square.add(new PVector(x, 50));
  }
  // Левая сторона квадрата:
  for (int y = 50; y > -50; y -= 10) {
    square.add(new PVector(-50, y));
  }
}

void draw() {
  background(51);

  // При помощи этой переменной будем следить,
  // как далеко вершины находятся от своей цели:
  float totalDistance = 0;
  
  // Проходим через каждую вершину:
  for (int i = 0; i < circle.size(); i++) {
    PVector v1;
    // Мы трансформируемся в круг или квадрат?
    if (state) {
      v1 = circle.get(i);
    }
    else {
      v1 = square.get(i);
    }
    // Считываем вершину, которую скоро нарисуем:
    PVector v2 = morph.get(i);
    // Движемся к цели:
    v2.lerp(v1, 0.1);
    // Проверяем, как далеко мы от цели:
    totalDistance += PVector.dist(v1, v2);
  }
  
  // Если все вершины находятся близко, 
  // переключаемся на другую фигуру:
  if (totalDistance < 0.1) {
    state = !state;
  }
  
  // Рисуем относительно центра:
  translate(width/2, height/2);
  strokeWeight(4);
  // Рисуем полигон, объединяющий в себе все вершины:
  beginShape();
  noFill();
  stroke(255);
  for (PVector v : morph) {
    vertex(v.x, v.y);
  }
  endShape(CLOSE);
}

См.также

Внешние ссылки