찾다
백엔드 개발PHP 튜토리얼php imagick 扩张合成图片的两张方法

php imagick 扩展合成图片的两张方法


方法一:compositeimages

/**     *  function: 合成图片     * @param  string      $output_url 图片保存路径     * @param  string      $img_type   图片保存类型     * @param  integral    $line_num   每行显示图片数量     * @param  array       $logo_info  每张待合成图片的信息(要求所有尺寸统一)     * @param  array       $img_list  待合成的图片绝对路径     *      * @return void     */    public function generate($output_url, $img_type, $line_num, $logo_info, $img_list=array()) {        //计算图片有多少行        $lines = ceil(count($img_list)/$line_num);        $bg_width = ($logo_info['width'] + $logo_info['line_width']) * $line_num;        $bg_height = ($logo_info['height'] + $logo_info['line_height']) * $lines;        //构建画布        $canvas = new Imagick();        $canvas->newimage($bg_width, $bg_height, 'white');        $canvas->setimageformat($img_type);        $i = $j = 0;        foreach ($img_list as $item) {            $im = new Imagick($item);            $x = $logo_info['line_width']*2 + $i * $logo_info['width'];            $y = $logo_info['line_height']*2 + $j * $logo_info['height'];                        // $canvas->compositeimage($im -> getimage(), Imagick::COMPOSITE_OVER, $x, $y);            $canvas -> compositeimage($im, $im->getImageCompose(), $x, $y);            if (($i + 1) % $line_num === 0) {                $i = 0;                $j++;            } else {                $i++;            }            // unset($im);            $im -> destroy();        }        $canvas->writeimage($output_url);        //销毁对象        $canvas -> destroy();    }



方法二:combineimages

/**     *  function: 合成图片     * @param  string      $output_url 图片保存路径     * @param  string      $img_type   图片保存类型     * @param  integral    $line_num   每行显示图片数量     * @param  array       $logo_info  每张待合成图片的信息(要求所有尺寸统一)     * @param  array       $img_list  待合成的图片绝对路径     *      * @return void     */    public function generate($output_url, $img_type, $line_num, $logo_info, $img_list=array()) {        //计算图片有多少行        $lines = ceil(count($img_list)/$line_num);        $bg_width = ($logo_info['width'] + $logo_info['line_width']) * $line_num;        $bg_height = ($logo_info['height'] + $logo_info['line_height']) * $lines;        //构建画布        $canvas = null;        $canvas = new Imagick();        $canvas -> newimage($bg_width, $bg_height, 'white');        $i = $j = 0;        foreach ($img_list as $item) {            $im = null;            $im = new Imagick($item);            // $canvas -> readImage($item);            $canvas -> addimage($im);            $im -> clear();            $im -> destroy();        }        // $canvas -> flattenImages();        $canvas -> combineImages( Imagick::CHANNEL_ALL );         $canvas -> writeimage($output_url);        //销毁对象        $canvas -> clear();        $canvas -> destroy();    }

个人认为方法二效率更高
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Vue和Canvas:如何实现手写签名和手势识别功能Vue和Canvas:如何实现手写签名和手势识别功能Jul 18, 2023 am 08:49 AM

Vue和Canvas:如何实现手写签名和手势识别功能引言:手写签名和手势识别功能在现代应用程序中越来越常见,它们可以为用户提供更加直观和自然的交互方式。Vue.js作为一款流行的前端框架,搭配Canvas元素可以实现这两个功能。本文将介绍如何使用Vue.js和Canvas元素来实现手写签名和手势识别功能,并给出相应的代码示例。一、手写签名功能实现要实现手写签

Canvas的优势有哪些Canvas的优势有哪些Aug 17, 2023 pm 04:52 PM

canvas的优势有强大的绘图功能、高性能、跨平台兼容性、支持多种图形格式、可以与其他Web技术集成、可以实现动态效果和可以实现复杂的图像处理。详细介绍:1、Canvas提供了丰富的绘图功能,可以绘制各种形状、线条、文本、图像等;2、Canvas在浏览器中直接操作像素,因此具有很高的性能;3、Canvas是基于HTML5标准的一部分,可以在各种现代浏览器上运行等等。

如何利用Vue和Canvas创建逼真的天气动态背景如何利用Vue和Canvas创建逼真的天气动态背景Jul 17, 2023 am 08:33 AM

如何利用Vue和Canvas创建逼真的天气动态背景引言:在现代网页设计中,动态背景效果是吸引用户眼球的重要元素之一。本文将介绍如何利用Vue和Canvas技术来创建一个逼真的天气动态背景效果。通过代码示例,你将学习如何编写Vue组件和利用Canvas绘制不同天气场景,从而实现一个独特而吸引人的背景效果。步骤一:创建Vue项目首先,我们需要创建一个Vue项目。

canvas特效有哪些canvas特效有哪些Aug 18, 2023 pm 04:12 PM

canvas特效有粒子效果、线条动画、图片处理、文字动画、音频可视化、3D效果、游戏开发等。详细介绍:1、粒子效果,通过控制粒子的位置、速度和颜色等属性来实现各种效果,如烟花、雨滴、星空等;2、线条动画,通过在画布上绘制连续的线条,创建出各种动态的线条效果;3、图片处理,通过对图片进行处理,可以实现各种炫酷的效果,如图片切换、图片特效等;4、文字动画等等特性。

canvas插件有哪些canvas插件有哪些Aug 17, 2023 pm 05:00 PM

canvas插件有Fabric.js、EaselJS、Konva.js、Three.js、Paper.js、Chart.js和Phaser。详细介绍:1、Fabric.js 是一个基于Canvas的开源 JavaScript 库,它提供了一些强大的功能;2、EaselJS是CreateJS库中的一个模块,它提供了一套简化了Canvas编程的API;3、Konva.js等等。

Vue和Canvas:如何实现视频播放器的定制化界面Vue和Canvas:如何实现视频播放器的定制化界面Jul 18, 2023 pm 02:49 PM

Vue和Canvas:如何实现视频播放器的定制化界面引言:在现代互联网时代,视频已经成为人们生活中必不可少的一部分。为了提供良好的用户体验,许多网站和应用程序都提供了自定义的视频播放器界面。本文将介绍如何使用Vue和Canvas技术实现一个定制化的视频播放器界面。一、前期准备在开始之前,您需要确保您已经安装了Vue和Canvas,并且熟悉这两种技术的基本用法

Vue和Canvas:如何实现图片的马赛克效果Vue和Canvas:如何实现图片的马赛克效果Jul 16, 2023 pm 10:17 PM

Vue和Canvas:如何实现图片的马赛克效果引言:随着Web技术的不断发展,越来越多的人开始使用Vue框架来构建交互式的前端应用。而在前端开发中,常常需要为用户提供图片处理的功能。本文将介绍如何利用Vue和Canvas实现图片的马赛克效果,为用户带来更好的视觉体验。一、马赛克效果概述马赛克效果是一种将图像的细节部分进行像素化处理,使得整个图像变得模糊和抽象

如何使用Vue和Canvas开发网页截图工具如何使用Vue和Canvas开发网页截图工具Jul 19, 2023 am 08:36 AM

如何使用Vue和Canvas开发网页截图工具简介:随着互联网的发展,网页截图工具在我们的日常生活中扮演着越来越重要的角色。它们可以用来捕捉网页上的信息、制作教程或者分享你的见解。本文将介绍如何使用Vue和Canvas来开发一个简单的网页截图工具,以帮助读者了解如何实现这个常见但又有趣的功能。准备工作:在开始之前,我们需要准备好以下的开发环境和工具:安装Nod

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구