Laravel框架使用图片处理简单教程

PHP图片处理扩展包使用

文中使用的是Laravel框架,更多框架扩展包请点击传送门-》更多框架集成

Intervention Image 是一个开源的 PHP 图像处理和操作 库。它提供了一个更简单也更优雅的方式来创建/编辑/组合图像,并且支持最常见的两个图像处理库 GD Library 和 Imagick 。

安装:

使用composer安装:

复制代码
composer require intervention/image

修改 app/config/app.php 添加 ServiceProvider 如果laravel 为高版本则不需要配置:

php 复制代码
//将下面代码添加到 providers 数组中
'providers' => [
 // ...
 Intervention\Image\ImageServiceProvider::class,
 // ...
 ],

// 将下面代码添加到 aliases 数组中
'aliases' => [
 // ...
 'Image' => Intervention\Image\Facades\Image::class,
 // ...
 ],

生成 config/image.php 配置文件:

shell 复制代码
php artisan vendor:publish --provider="Intervention\Image\ImageServiceProviderLaravel5"

运行上面的命令后, 会在项目中生成 config/image.php 配置文件, 打开此文件并将 driver 修改成 imagick 或者 gd (如果图片超过8000像素则使用imagick,gd库可能执行不了):

php 复制代码
return array(
'driver' => 'imagick'
);

图像格式支持

可读的图像格式取决于使用的驱动程序。而使用 Imagick 时,它是 可以读取库本身支持的所有格式,仅使用 GD 某些格式是可读和可写的。

基础用法

php 复制代码
// 打开画布
    $img = Image::make('ikun.jpg')->resize(800,800);

// 根据坐标在图片上画一个红色的长方形框
$img->rectangle(10, 11, 14, 16, function ($draw) {
        //背景色
        $draw->background('rgba(255, 255, 255, 0)');
        //边框大小,颜色
        $draw->border(2, '#FF0000');
    });
// 输出图片调试
    $response = Response::make($img->encode('jpg'));
    $response->header('Content-Type', 'image/jpg');

// 将处理后的图片重新保存到其他路径
$img->save('new_ikun.jpg');

下面就是我们运行的结果,输出图片,并将图片保存到了根目录

intervention提供了非常全面的接口用法,使用方法请查看官网最新文档-》传送门

总结

以上就是在Laravel框架使用图片处理的简单教程。确保阅读intervention的官方文档,根据自己的理解去探索。

相关推荐
PyAIExplorer5 小时前
图像处理中的插值方法:原理与实践
图像处理·人工智能
Sally璐璐5 小时前
IPSAN 共享存储详解:架构、优化与落地实践指南
开发语言·php
程序猿阿伟7 小时前
《声音的变形记:Web Audio API的实时特效法则》
开发语言·前端·php
Clownseven7 小时前
Shell 脚本实战指南:内网 ARP 洪泛监控与飞书/邮件自动告警
网络·php·飞书
浪裡遊17 小时前
React Hooks全面解析:从基础到高级的实用指南
开发语言·前端·javascript·react.js·node.js·ecmascript·php
超龄超能程序猿18 小时前
(三)PS识别:基于噪声分析PS识别的技术实现
图像处理·人工智能·计算机视觉
加油吧zkf1 天前
AI大模型如何重塑软件开发流程?——结合目标检测的深度实践与代码示例
开发语言·图像处理·人工智能·python·yolo
ejinxian1 天前
PHP 超文本预处理器 发布 8.5 版本
开发语言·php
zorro_z1 天前
PHP语法基础篇(九):正则表达式
php
高压锅_12201 天前
思科与华为网络设备命令对比指南:从基础操作到高级配置
服务器·华为·php