CodeLAB
на главную карта сайта обратная связь

Популярные задачи:

#Хранение иерархических деревьев. (55631 hits)
#Часики на js. (99988 hits)
#Динамическое изменение цвета полоски прокрутки в IE5.5 и выше. (32717 hits)
#Сравнение алгоритмов быстрой сортировки. (77097 hits)
#"The Java Programming Language" Ken Arnold, James Gosling, David Holmes листинги, код, примеры из книги, исходники. (63303 hits)
#Плоттеры для рисования графиков. (31522 hits)
#Сортировка выбором, общий подход. (76324 hits)
#Сравнение алгоритмов сортировки массива. (188900 hits)
#Перестановка фрагментов строки(или одномерного массива). (63706 hits)
#Замена символа строки. (447338 hits)
#Поразрядная сортировка массива подсчетом. (137090 hits)
#Вычисление среднего, среднего отклонения, среднеквадратического отклонения и дисперсии заданной выборки. (48695 hits)
#Обновление нескольких записей таблицы. (34393 hits)
#Курсы валют. (70136 hits)
#Валидация, динамическая проверка заполнения html форм. (213031 hits)
#Простая быстрая сортировка. (116629 hits)
#Глубокое полное клонирование. (37877 hits)
#Подсветка синтаксиса. (33490 hits)
#Посчитать количество пар чисел (number of equal pairs). (10925 hits)
#Улучшение быстрой сортировки. (81344 hits)


Главная >> Каталог задач >> Веб-разработка >> Серверный скриптинг >> Работа с изображениями >>

Масштабирование, пропорциональное изменение размеров картинки

Aвтор:
Дата:
Просмотров: 106552
реализации(php: 6шт...) +добавить

Задача возникает при создании превьюшек(небольших иконок) из имеющихся больших изображений. В данном случае необходимо сделать уменьшенный пропорциональный вариант нашей картинки, высота и ширина которого не будет превышать заданных значений.

Формализация

На входе:

  1. Путь к файлу содержащему исходное большое изображение
  2. Путь к файлу, в котором будет получена уменьшенная копия
  3. Максимально допустимая ширина уменьшенной копии
  4. Максимально допустимая высота уменьшенной копии

На выходе нужно чтобы по пути в п.2 - мы получили бы искомую превьюшку, размеры которой не превышают указанных.

Алгоритм

  1. Получаем размеры исходной картинки
  2. На их основе рассчитываем коэфициент пропорции по отношению к уменьшенной копии
  3. На основе рассчитанного коэфициэнта - получаем новые размеры.
  4. Уменьшаем исходное изображение до указанных размеров.

Все пункты кроме 2-го - не представляют большого интереса, т.к. реализуются специфическими фукнциями того или иного языка и легко находятся в документации.

П.2 - может быть реализован по-разному. Нужно найти такой коэфициэнт, который даст новые высоту и ширину, не превышающие указанные.

Для этого нужно рассчитывать пропорцию от большего значения из 2-х(высота и ширина исходной картинки):

 псевдокод: Расчет коэфициэнта пропорции  ссылка
  1. // Рассчитываем коэфициент
  2. // imgWidth, imgHeight - исходные размеры
  3. if imgWidth > imgHeight
  4. ratio = maxWidth / imgWidth
  5. else
  6. ratio = maxHeight / imgHeight
  7.  
  8. newWidth = ratio * imgWidth
  9. newHeight = ratio * imgHeight

Реализации:

php(6)   +добавить

1) Вычисление коэфициэнта пропорции от большей величины на php, code #99[автор:this]
2) Вариант №1 из комментов к документации php на php, code #100[автор:-]
3) Вариант №2 из комментов к документации php на php, code #101[автор:-]
4) Вариант №3 из комментов к документации php на php, code #102[автор:-]
5) Вариант №4 из комментов к документации php на php, code #103[автор:-]
6) php image resize на php, code #628[аноним:Сергей]