php imagepng в файл

imagecreatefrompng

(PHP 4, PHP 5, PHP 7, PHP 8)

imagecreatefrompng — Создаёт новое изображение из файла или URL

Описание

imagecreatefrompng() возвращает идентификатор изображения, представляющего изображение полученное из файла с заданным именем.

Список параметров

Путь к изображению PNG.

Возвращаемые значения

Возвращает объект изображения в случае успешного выполнения или false в случае возникновения ошибки.

Список изменений

ВерсияОписание
8.0.0В случае успешного выполнения функция теперь возвращает экземпляр GDImage ; ранее возвращался ресурс ( resource ).

Примеры

Пример #1 Пример обработки ошибки при загрузке PNG

header ( ‘Content-Type: image/png’ );

$img = LoadPNG ( ‘bogus.image’ );

Результатом выполнения данного примера будет что-то подобное:

php imagepng в файл. Смотреть фото php imagepng в файл. Смотреть картинку php imagepng в файл. Картинка про php imagepng в файл. Фото php imagepng в файл

User Contributed Notes 7 notes

If you’re trying to load a translucent png-24 image but are finding an absence of transparency (like it’s black), you need to enable alpha channel AND save the setting. I’m new to GD and it took me almost two hours to figure this out.

I had the same problem as jboyd1189 at yahoo dot com but I solve d it allocating more memory dynamically.

The approach I used to solve the problem is:

1-Calculate the memory required by the image
2-Set the new memory_limit value
3-Create the PNG image and thumbnail
4-Restore the original value

Because gd and imagick do not support animated PNG (at this moment), i wrote a simple function to determine if given PNG is APNG or not. It does not validate PNG, only checks whenever «acTL» chunk appears before «IDAT» like the specification says: https://wiki.mozilla.org/APNG_Specification

When using imagecreatepng with alpha blending you will lose the blending.

This will create a true colour image then copy the png image to this true colour image and retain alpha blending.

Источник

Справочник по PHP : Графика : Работа с изображениями и библиотека GD : Манипулирование изображениями

смотрим также

Материал из Справочник Web-языков

Содержание

imageCreate

Создание пустой картинки.

Создает пустую картинку размером x на y точек и возвращает ее идентификатор. После того, как картинка создана, вся работа с ней осуществляется именно через этот идентификатор, по аналогии с тем, как мы работаем с файлом через его дескриптор.

Создание новой картинки при помощи GD и вывод ее в экран браузера:

imageCreateFromPng

Создание рисунка из файла PNG.

Эта функция загружают изображения из файла PNG в память и возвращает его идентификатор. Как и после вызова imageCreate(), дальнейшая работа с картинкой возможна только через этот идентификатор. При загрузке с диска изображение распаковывается и храниться в память уже в неупакованном формате, для того чтобы можно было максимально быстро производить с ним различные операции, такие как масштабирование, рисование линий и т.д.

Пример нахождения ошибки при открытии графического файла.

imageCreateFromJpeg

Создание рисунка из файла JPEG.

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

imageCreateFromGif

Создание рисунка из файла GIF.

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

Стоит упомянуть, что GD начиная с версии 1.6 не поддерживает формат GIF. В связи с этим данная функция практически не используется.

imagePng

Функция выводит изображение в PNG-формате в любой браузер или в файл.

Эта функция сохраняет изображение, заданное своим идентификатором и находящееся в памяти, на диск, или же выводят его в браузер.

Разумеется, вначале изображение должно быть загружено или создано при помощи функции imageCreate(), т.е. мы должны знать его идентификатор im.

Если аргумент filename опущен, то сжатые данные в соответствующем формате выводятся прямо в стандартный выходной поток, т.е. в браузер. Нужный заголовок Content-type при этом не выводится, ввиду чего нужно выводить его вручную при помощи Header().

Фактически, вы должны вызвать одну из трех команд, в зависимости от типа изображения:

Header(«Content-type: image/png») для PNG.

Пример: Пример использования функции imagepng():

Для сохранения alpha-канала исходного изображения необходимо применять функцию imagesavealpha():

imageJpeg

Отсылка рисунка JPEG браузеру или сохранение его в файле.

Эта функция сохраняет изображение, заданное своим идентификатором и находящееся в памяти, на диск, или же выводит его в браузер.

Разумеется, вначале изображение должно быть загружено или создано при помощи функции imageCreate(), т.е. мы должны знать его идентификатор im.

Если аргумент filename опущен, то сжатые данные в соответствующем формате выводятся прямо в стандартный выходной поток, т.е. в браузер. Нужный заголовок Content-type при этом не выводится, ввиду чего нужно выводить его вручную при помощи Header().

Фактически, вы должны вызвать одну из трех команд, в зависимости от типа изображения:

Header(«Content-type: image/jpeg») для Jpeg

Третий необязательный параметр quality задает качество изображения (от 0 до 100).

image2WBMP

Вывод изображения в браузер или файл.

Функция выводит изображение, заданное дескриптором image, в браузер, либо в файл, имя которого задано необязательным параметром filename.

Если изображение выводится в браузер, необходимо задать его тип WBMP как image/vnd.wap.wbmp функцией Header():

Функция image2WBMP() доступна PHP только если версия библиотеки GD 1.8 или ниже.

imageGif

Отсылка рисунка GIF браузеру или сохранение его в файле.

Функция сохраняют изображение, заданное своим идентификатором и находящееся в памяти, на диск, или же выводят его в браузер.

Разумеется, вначале изображение должно быть загружено или создано при помощи функции imageCreate(), т.е. мы должны знать его идентификатор im.

Если аргумент filename опущен, то сжатые данные в соответствующем формате выводятся прямо в стандартный выходной поток, т.е. в браузер. Нужный заголовок Content-type при этом не выводится, ввиду чего нужно выводить его вручную при помощи Header().

Фактически, вы должны вызвать одну из трех команд, в зависимости от типа изображения:

Т.к. библиотека GD, начиная с версии 1.6, не поддерживает формат GIF, данная функция используется редко.

imageCopy

Копирование части рисунка.

Функция копирует прямоугольную область начиная с позиции (src_x, src_y) шириной src_w и высотой src_h из рисунка src_im в рисунок dst_im, придав копируемой области смещение (dst_x, dst_y).

В следующем примере будет картинка file1.png целиком скопирована в file2.png

imageCopyResized

Копирование части рисунка с масштабированием.

dst_im задает идентификатор изображения, в который будет помещен результат работы функции. Это изображение должно уже быть создано или загружено и иметь надлежащие размеры.

Наконец, четверка dstX, dstY, dstW, dstH задает то место на изображении dst_im, в которое будет «втиснут» указанный в предыдущей четверке прямоугольник. Заметьте, что, если ширина или высота двух прямоугольников не совпадают, то картинка автоматически будет нужным образом растянута или сжата.

В следующем примере файл file1.jpg уменьшается вдвое и записывается в файл file2.jpg:

imageDestroy

Функция уничтожает дескриптор im ранее созданного рисунка (наподобие закрытия файла fclose() после открытия fopen()).

Источник

Использование готовых изображений

В PHP можно не только создать изображение с нуля, но и загрузить существующее. Это делается с помощью функций, каждая из которых загружает изображение своего формата. Функция imageCreateFromJpeg() использует файл в формате jpeg. Возвращает дескриптор изображения. Загрузим файл picture.jpg из папки phpimages. Вы можете использовать эту картинку:

php imagepng в файл. Смотреть фото php imagepng в файл. Смотреть картинку php imagepng в файл. Картинка про php imagepng в файл. Фото php imagepng в файл

Напишем скрипт, который загружает изображение из файла и выводит в браузер:

Это обычное изображение, с ним можно работать, добавлять на него различные фигуры. Обратите внимание, использованный файл имеет один формат, а вывод картинки сделан в другом формате. Это вполне допустимо.

Существуют функции и для других форматов. Набор поддерживаемых форматов зависит от сборки PHP. Во всех функциях вместо адреса файла можно указать URL. Для этого в файле php.ini должна быть включена опция allow_url_fopen, позволяющая загружать файлы из интернета.

Иногда нужна не вся картина, а только её часть. Тогда нужно сделать так:

imageCopy (принимающее изображение, оригинал, X принимающего, Y принимающего, X оригинала, Y оригинала, ширина, высота)

В параметрах указываются координаты левого верхнего угла копируемой части. Выведем на экран часть картинки из файла:

php imagepng в файл. Смотреть фото php imagepng в файл. Смотреть картинку php imagepng в файл. Картинка про php imagepng в файл. Фото php imagepng в файл

Функция imageCopyResized() копирует часть картинки и изменяет её размеры.

imageCopyResize (принимающее изображение, оригинал, X принимающего, Y принимающего, X ориринала, Y оригинала, новая ширина, новая высота, оригинальная ширина, оригинальная высота)

Новые размеры копируемой части 480 на 235. Картинка выглядит так:

php imagepng в файл. Смотреть фото php imagepng в файл. Смотреть картинку php imagepng в файл. Картинка про php imagepng в файл. Фото php imagepng в файл

Попробуйте использовать обе функции. Сделайте разные варианты изменения размеров.

Коприрование материалов сайта возможно только с согласия администрации

Источник

imagecreatefromstring

(PHP 4 >= 4.0.4, PHP 5, PHP 7, PHP 8)

imagecreatefromstring — Создание нового изображения из потока представленного строкой

Описание

Список параметров

Строка содержащая данные изображения.

Возвращаемые значения

Ошибки

imagecreatefromstring() вызывает ошибку уровня E_WARNING, если данные в неподдерживаемом формате.

Список изменений

ВерсияОписание
8.0.0В случае успешного выполнения функция теперь возвращает экземпляр GDImage ; ранее возвращался ресурс ( resource ).
7.3.0Добавлена поддержка WEBP (если поддерживается используемой libgd).

Примеры

Пример #1 Пример использования imagecreatefromstring()

Результатом выполнения данного примера будет что-то подобное:

php imagepng в файл. Смотреть фото php imagepng в файл. Смотреть картинку php imagepng в файл. Картинка про php imagepng в файл. Фото php imagepng в файл

Смотрите также

User Contributed Notes 17 notes

While downloading images from internet, it’s easiest to let php decide what is the file type. So, forget using imagecreatefromjpg, imagecreatefromgif and imagecreatefrompng. Instead, this is the way to go:

My site allows anonymous uploads to a web-accessible location (that will execute a script if it finds one).

Naturally, I need to verify that only harmless content is accepted. I am expecting only images, so I use:

So you guys don’t spend an hour trying to figure out why your script keeps running out of memory when you’re using this or the other imagecreatefrom functions. GD uncompresses the image when you use these functions, and this can lead to your script running out of memory.

If you download a rawimage save it on your computer to jpeg so the file size comes down, GD will automatically convert it to the raw and you can possibly run out of memory.

[Editor’s note: BMP will be supported as of PHP 7.2.0.]

In case it’s not obvious from the lack of «imagecreatefrombmp()» in GD, this function cannot handle plain old BMP files either.

I know a lot of people have been having trouble using images from the Sprint PPC6700 with GD. The jpeg library always thows an error about 16 bytes of extraneous data. I decided to poke around in a hex editor and found those extraneous bytes occur right at the end of the exif data.

By removing this extraneous data, images can easily be manipulated by GD and the EXIF extension as a normal images. This also removes any problems using the images with GIMP which must rely on the same jpeg libraries.

Here is a function that will check to see if an image is from the PPC6700 and then remove the extraneous data for you. The result can successully be used with imagecreatefromstring

Author: Paul Visco
IM: paulsidekick
Created: 2-12-06

//get the file contents
$data = file_get_contents($orig);

I use dynamically generated images that require a little touch-up before being displayed. So essentially I do some base work, then store the images in a memory cache (APC), reload the images again from the cache later on «into» GD, do final processing and then display the image.
Since I wanted to avoid a lot of disc access I used the output buffering functions:

// Do your image processing stuff

// Put stuff into cache

// Do final editing stuff and output image
?>

Of course this is a condensed example but I just wanted to share the idea.

An easy example to help understanding this function.

The function will try to auto-determine file format (jpg, gif, png. ), and will return false if fails.

Create an image resource from file, without knowing image type:

A note to the previous question (if you still don’t know it :)).

GIF’s are 256 colors (or 8 bit), and the resample function needs true color I guess. that’s why it works with JPG’s and not with GIF’s.

Next thing. you take a string, write it to file, open the file (imagecreatefromgif), and delete the file again.

if you do imagecreatefromstring($string) you can skip the temporary file part.

If you let them, the PHP function will return an error «Data is not in a recognized format in».

If you have this situation :

$image_string=str_replace(«data:image/png;base64,»,»»,$image_string);
$image_string = base64_decode($image_string);
$img = imagecreatefromstring($image_string);

I run a blogging site that allowed users to publish images from their cell phones. For some reason, the nokia 3220 produces jpegs with extrandeous data before the EOF 0xFFF9

I wrote this class to allow you to fix the images so that they can be used with GD to resize and manipulate. Without applying the fix both GD and gimp report errors for the file. If basically keeps eating bytes from the junk part till the file is a valid jpeg. Here is an example bunk pic written by a nokia 3220 that you cna test it with http://www.shawnrider.com/moblog/cache/0854747001121624103.jpg

/*
Author: Paul Visco
Hompage: http://www.elmwoodstrip.com?u=paul
AIM: paulsidekick
Notes: The file allows you fix the jpegs created by the Nokia 3220 picture phone so that they can be manipulated using the GD library with PHP.

Usage: Simply instanitiate the class and then call the fix method for each image.
e.g.
$nokia = new nokia;
$nokia->debug =»y»;
$nokia->fix(«yourpic.jpg»);
*/

//load the file into a string
$this->str = file_get_contents($this->file);

//test to see if it is a nokia image or if it has been corrupted previously
if (substr_count($this->str, chr(0x28).chr(0x36).chr(0x28).chr(0x2B)) == 0 || @imagecreatefromstring($this->str))
<
if ($this->debug ==»y»)
<
echo «\n
«.$this->file.» is not a corrupted Nokia pic»;
>

//strip out the funk e crap from the file
$this->eat($this->str);

//return true for fixed
return true;

//check the image
$this->img = @imagecreatefromstring($this->str);

//check the image again
$this->img = @imagecreatefromstring($this->str);
>

if ($this->debug ==»y»)
<
//notify the user it’s fixed
echo «\n
Nasty bits eaten!! «.$this->file.» is fixed now thanks to p:labs!»;
>
return true;
>

The only way I managed to resolve the loading of image files from file data either on local site or from off-site protocols is as follows. I hope this saves someone else the two hours of debugging and looking for good examples.
[PHP]

Here is the code I did to create a thumbnail image from the database blob field. The trick is to use «imagecreatefromstring()» to create an image file.

Источник

imagecopyresized

(PHP 4, PHP 5, PHP 7, PHP 8)

imagecopyresized — Копирование и изменение размера части изображения

Описание

Если координаты, ширина или высота исходного и конечного изображений различны, копируемый фрагмент будет растянут или сжат. Координаты отсчитываются от левого верхнего угла изображения. Функцию можно использовать для наложения участков на то же изображение, с которого они скопированы (если dst_image имеет то же значение, что и src_image ), но если участки будут пересекаться, результат непредсказуем.

Список параметров

Ресурс целевого изображения.

Ресурс исходного изображения.

x-координата результирующего изображения.

y-координата результирующего изображения.

x-координата исходного изображения.

y-координата исходного изображения.

Ширина исходного изображения.

Высота исходного изображения.

Возвращаемые значения

Возвращает true в случае успешного выполнения или false в случае возникновения ошибки.

Список изменений

ВерсияОписание
8.0.0dst_image и src_image теперь ожидают экземпляр GdImage ; ранее ожидался ресурс ( resource ).

Примеры

Пример #1 Изменение размера изображения

В этом примере размер изображения будет уменьшен в два раза.

// файл и новый размер
$filename = ‘test.jpg’ ;
$percent = 0.5 ;

// тип содержимого
header ( ‘Content-Type: image/jpeg’ );

Результатом выполнения данного примера будет что-то подобное:

php imagepng в файл. Смотреть фото php imagepng в файл. Смотреть картинку php imagepng в файл. Картинка про php imagepng в файл. Фото php imagepng в файл

Примечания

Смотрите также

User Contributed Notes 33 notes

Most of the examples below don’t keep the proportions properly. They keep using if/else for the height/width..and forgetting that you might have a max height AND a max width, not one or the other.

If you read your Imagedata from a Database Blob and use the functions from above to resize the image to a thumbnail improving a lot of traffic, you will have to make temporary copies of the files in order that the functions can access them

// get a temporary filename
// use microtime() to get a unique filename
// if you request more than one file f.e. by creating large numbers of thumbnails, the server could be not fast enough to save all these different files and you get duplicated copies and resizepics() will resize and output often the same content

// open
$tempfile = fopen($filename, «w+»);

// write
fwrite($tempfile, mysql_result($query, 0, ‘image’));

// resize and output the content
echo resizepics($filename, ‘100’, ’70’);

// delete temporary file
unlink($filename);

NOTE: this script has to be put into a file which sends correct header informations to the browser, otherwise you won’t get more to see than a big red cross 🙂

Resize image proportionaly where you give a max width or max height

If you need to delete or resize images in the filesystem (not in DB) without loosing the image quality.
I commented the code as much as possible so that newbies (like myself) will understand it. 😉

WRITTEN BY:
Finnur Eiriksson, (http://www.centrum.is/finnsi)
Based on snippets that have been posted on www.PHP.net
Drop me an e-mail if you have any questions.

Belows is the code snipet that allows you to resize a transparent PNG and composite it into another image. The code is tested to work with PHP5.1.2, GD2, but I think it can also work with other versions of PHP and GD.

The code has been commented to help you read through it. The idea of resizing the transparent PNG image is to create a new destination image which is completely transparent then turn off the imageAlphaBlending of this new image so that when the PNG source file is copied, its alpha channel is still retained.

/* Open the photo and the overlay image */
$photoImage = ImageCreateFromJPEG ( ‘images/MiuMiu.jpg’ );
$overlay = ImageCreateFromPNG ( ‘images/hair-trans.png’ );

Источник

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *