Thursday, 29 September 2016

Watermark an uploaded Image with PHP

Watermarking is a popular method to protect digital photos from being copied by the picture thieves on the net. Using PHP we can do the same. Here we use a transparent PNG image as Watermark template, we then merge it with image to create a permanent watermark.

In most scenarios people want to resize uploaded image using HTML form and then watermark it on the fly. So in this article, we will do the same. We upload an image, resize it and then watermark it with our PNG file.



If you look at my previous resize snippet, you’ll realize that I have made a slight modification to the code. This snippet typically does the same thing, it resizes uploaded image. But after modification, now it adds a watermark to all resized images. Let’s create an upload page using HTML below.
<!DOCTYPE HTML>
<html>

<head>
    <style type="text/css">
        #upload-form {
            padding: 20px;
            background: #F7F7F7;
            border: 1px solid #CCC;
            margin-left: auto;
            margin-right: auto;
            width: 400px;
        }
        
        #upload-form input[type=file] {
            border: 1px solid #ddd;
            padding: 4px;
        }
        
        #upload-form input[type=submit] {
            height: 30px;
        }
    </style>
</head>

<body>

    <form action="" id="upload-form" method="post" enctype="multipart/form-data">
        <input type="file" name="image_file" />
        <input type="submit" value="Send Image" />
    </form>

</body>


</html>



Complete snippet (Re-size and Watermark)


If you are clear on the example above, take a look at the complete PHP code below, we call PHP imagecopy() function after the image is resized, but before saving the image.

<?php

if(isset($_FILES['image_file']))
{
$max_size = 800; //max image size in Pixels
$destination_folder = 'M:/xampp/htdocs/demo/php-watermark-sample-file';
$watermark_png_file = 'watermark.png'; //watermark png file

$image_name = $_FILES['image_file']['name']; //file name
$image_size = $_FILES['image_file']['size']; //file size
$image_temp = $_FILES['image_file']['tmp_name']; //file temp
$image_type = $_FILES['image_file']['type']; //file type

switch(strtolower($image_type)){ //determine uploaded image type 
//Create new image from file
case 'image/png': 
$image_resource =  imagecreatefrompng($image_temp);
break;
case 'image/gif':
$image_resource =  imagecreatefromgif($image_temp);
break;          
case 'image/jpeg': case 'image/pjpeg':
$image_resource = imagecreatefromjpeg($image_temp);
break;
default:
$image_resource = false;
}

if($image_resource){
//Copy and resize part of an image with resampling
list($img_width, $img_height) = getimagesize($image_temp);

   //Construct a proportional size of new image
$image_scale        = min($max_size / $img_width, $max_size / $img_height); 
$new_image_width    = ceil($image_scale * $img_width);
$new_image_height   = ceil($image_scale * $img_height);
$new_canvas         = imagecreatetruecolor($new_image_width , $new_image_height);

if(imagecopyresampled($new_canvas, $image_resource , 0, 0, 0, 0, $new_image_width, $new_image_height, $img_width, $img_height))
{

if(!is_dir($destination_folder)){ 
mkdir($destination_folder);//create dir if it doesn't exist
}

//center watermark
$watermark_left = ($new_image_width/2)-(300/2); //watermark left
$watermark_bottom = ($new_image_height/2)-(100/2); //watermark bottom

$watermark = imagecreatefrompng($watermark_png_file); //watermark image
imagecopy($new_canvas, $watermark, $watermark_left, $watermark_bottom, 0, 0, 300, 100); //merge image

//output image direcly on the browser.
header('Content-Type: image/jpeg');
imagejpeg($new_canvas, NULL , 90);

//Or Save image to the folder
//imagejpeg($new_canvas, $destination_folder.'/'.$image_name , 90);

//free up memory
imagedestroy($new_canvas); 
imagedestroy($image_resource);
die();
}
}
}
?>


Watermark an uploaded Image with PHP

No comments:

Post a Comment