<MyRusakov.ru />

Профессиональная Web-разработка. Дизайн, код и автоматизация

Профессиональная Web-разработка. Дизайн, код и автоматизация

Это очень подробный курс из разряда "всё включено". Разбираются следующие темы: HTML, CSS, SCSS, JavaScript, PHP, SQL, Laravel, Nginx, PostCSS, npm, Vite, Vitest, Composer, PHPUnit, Prettier, Stylelint, ESLint, Pint, Larastan, Git, Agile, Scrum, Docker, Supervisord, Figma, Stitch AI, Confluence, Jira.

Рассчитан и на новичков, и на тех, кто уже знаком с основами, но хочет освоить полный цикл разработки.

Помимо самой теории, Вы увидите пример создания Web-проекта на 20 000 строк кода: от идеи и документации на Confluence через планирование на Jira, fullstack-разработку до деплоя на VPS.

Помимо уроков, курс содержит упражнения для закрепления знаний и финальное тестирование. А ещё Вы получите 5 полноценных Бонусных курсов: «GitLab под ключ», «Вёрстка сайта с нуля 2.0», «JavaScript с Нуля до Гуру 2.0», «PHP и MySQL с Нуля до Гуру 3.0» и «Laravel от А до Я».

Подробнее
Подписка

Подпишитесь на мой канал на YouTube, где я регулярно публикую новые видео.

YouTube Подписаться

Подписавшись по E-mail, Вы будете получать уведомления о новых статьях.

Подписка Подписаться

Добавляйтесь ко мне в друзья ВКонтакте! Отзывы о сайте и обо мне оставляйте в моей группе.

Мой аккаунт Мой аккаунт Моя группа
Опрос

Какая тема Вас интересует больше?

Конвертирование изображения из формата PNG в формат JPEG в JavaScript

Конвертирование изображения из формата PNG в формат JPEG в JavaScript

Доброго времени суток! Сегодня мы рассмотрим с Вами как преобразовать изображение из формата PNG в формат JPEG прямо в браузере с сохранением соотношения сторон.

Код с комментариями:

// Экспортируем функцию pngToJpeg для доступа из других модулей
/**
 * @param {String} pngFile - объект File, полученный при выборе пользователем файла с устройства
 */
export function pngToJpeg(pngFile, maxWidth = 1200) {
    // Создаем новое обещание (Promise), чтобы асинхронно выполнить операции с изображением
    return new Promise((resolve, reject) => {
        // Создаем новый объект FileReader для чтения содержимого файла
        const reader = new FileReader();

        // Устанавливаем обработчик события загрузки файла
        reader.onload = () => {
            // Создаем новый объект Image для загрузки изображения
            const img = new Image();

            // Устанавливаем обработчик события загрузки изображения
            img.onload = () => {
                // Создаем новый элемент canvas и получаем его 2D контекст для рисования
                const canvas = document.createElement('canvas');
                const context = canvas.getContext('2d');

                // Вычисляем соотношение сторон исходного изображения
                const aspectRatio = img.width / img.height;

                // Рассчитываем новые размеры изображения на основе максимальной ширины и соотношения сторон
                const newWidth = maxWidth;
                const newHeight = newWidth / aspectRatio;

                // Устанавливаем новые размеры для элемента canvas
                canvas.width = newWidth;
                canvas.height = newHeight;

                // Рисуем изображение на canvas с новыми размерами
                context.drawImage(img, 0, 0, newWidth, newHeight);

                // Преобразуем содержимое canvas в объект Blob с форматом JPEG и передаем его как результат обещания
                canvas.toBlob((blob) => {
                    resolve(blob);
                }, 'image/jpeg');
            };

            // Устанавливаем обработчик события ошибки при загрузке изображения
            img.onerror = (error) => {
                reject(error);
            };

            // Устанавливаем источник изображения для объекта Image (приводит к тому, что изображение начинает загружаться)
            img.src = reader.result;
        };

        // Устанавливаем обработчик события ошибки чтения файла
        reader.onerror = (error) => {
            reject(error);
        };

        // Читаем содержимое файла в формате Data URL с помощью FileReader
        reader.readAsDataURL(pngFile);
    });
}


Данный код конвертирует изображение из формата PNG в формат JPEG с сохранение соотношения сторон.

Копирование материалов разрешается только с указанием автора (Михаил Русаков) и индексируемой прямой ссылкой на сайт (https://myrusakov.ru)!

Добавляйтесь ко мне в друзья ВКонтакте: https://vk.com/myrusakov.
Если Вы хотите дать оценку мне и моей работе, то напишите её в моей группе: https://vk.com/rusakovmy.

Если Вы не хотите пропустить новые материалы на сайте,
то Вы можете подписаться на обновления: Подписаться на обновления

Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.

Порекомендуйте эту статью друзьям:

Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):

  1. Кнопка:

    Она выглядит вот так: Как создать свой сайт

  2. Текстовая ссылка:

    Она выглядит вот так: Как создать свой сайт

  3. BB-код ссылки для форумов (например, можете поставить её в подписи):

Комментарии (0):

Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.