Laravel Generate Image With Watermark Example

10-Apr-2023

.

Admin

Laravel Generate Image With Watermark Example

Hi Friends,

I am going to explain you example of laravel generate image with watermark example. Inside this article we will see the how to add watermark on image in laravel. This article contains a very classified information about the basic concept of laravel add text overlay watermark on image tutorial.

We will see the concept of add watermark on images in laravel. This example use to easy way to add watermark on images in laravel.

So let's start following step.

Step : 1 - Installation of Laravel Application


Use this command then download laravel project setup :

composer create-project --prefer-dist laravel/laravel blog

Step : 2 - You have to add package on your laravel project by using composer like

composer require intervention/image

Step 3 : Then you have to add provider path and alias path in config/app.php file like

config/app.php

'providers' => [

Intervention\Image\ImageServiceProvider::class,

]

'aliases' => [

'Image' => Intervention\Image\Facades\Image::class,

]

Step 4 : Create route

route/web.php

<?php

use Illuminate\Support\Facades\Route;

/*

|--------------------------------------------------------------------------

| Web Routes

|--------------------------------------------------------------------------

|

| Here is where you can register web routes for your application. These

| routes are loaded by the RouteServiceProvider within a group which

| contains the "web" middleware group. Now create something great!

|

*/

Route::get('/generate-image-text', array('as'=> 'generate.image.text', 'uses' => 'ImageController@generateImageText'));

Route::post('/generate-image-text-store', array('as'=> 'generate.image.text.store', 'uses' => 'ImageController@generateImageTextStore'));

Step 5 : Create Controller

php artisan make:controller ImageController

app/Http/Controller/ImageController.php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

use Image;

class ImageController extends Controller

{

/**

* Generate Image View

*

* @return void

*/

public function generateImageText(){

return view('index');

}

/**

* Store Generate Image

*

* @return void

*/

public function generateImageTextStore(Request $request){

$text = $request->input('text');

if($request->file('name') != ""){

$file = $request->file('name');

$file_name = time().'_'.$file->getClientOriginalName();

$img = Image::make($file);

$watermark = $request->file('watermark');

$watermark_name = time().'_'.$watermark->getClientOriginalName();

$img2 = Image::make($watermark);

$img2->save(public_path('test.png',$watermark_name));

$img->text($text,500,220,function($font){

$font->file(public_path("Open_Sans/OpenSans-Italic-VariableFont_wdth,wght.ttf"));

$font->size(40);

$font->color("#ff0000");

$font->align("center");

$font->valign("top");

});

$img->insert(public_path('test.png') ,'bottom-right', 15, 15);

$img->save(public_path($file_name));

return $img->response("jpg");

}

return back();

}

}

Step 6 : Create blade file

resources/view/index.blade.php

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<meta name="viewport" content="width=device-width, initial-scale=1">

<title>Laravel Generate Image With Watermark - Nicesnippets.com</title>

<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.6.1/dist/css/bootstrap.min.css">

</head>

<body>

<div class="container">

<div class="row justify-content-md-center mt-5">

<div class="col-md-8 border p-4 mt-5">

<h3>Laravel Generate Image With Watermark - Nicesnippets.com</h3>

{{!! Form::open(array('route' => 'generateImageTextStore','method' => 'post','files' => true ,'class' => 'mt-4')) !!}}

@csrf

<div class="form-group">

{{ Form::label('Enter Text:') }}

{{ Form::textarea('text','',array('class' => 'form-control','rows' => '3','placeholder' => 'Enter Text Here ...')) }}

</div>

<div class="form-group">

{{ Form::label('Enter Image:') }}

{{ Form::file('name',array('class' => 'form-control')) }}

</div>

<div class="form-group">

{{ Form::label('Enter Watermark Image:') }}

{{ Form::file('watermark',array('class' => 'form-control')) }}

</div>

{{ Form::submit('Submit',array('class' => 'btn btn-primary mt-2')); }}

{!! Form::close() !!}

</div>

</div>

</div>

</body>

</html>

Output:

I hope it can help you...

#Laravel