thinkphp3.2+cropper는 여러 장의 사진 업로드 및 자르기를 구현합니다(코드 예).
이 글의 내용은 여러 장의 사진을 업로드하고 잘라낼 수 있는 thinkphp3.2+cropper(코드 예제)를 소개하는 것입니다. 필요한 친구들이 참고하면 도움이 될 것입니다. 너.
먼저 달성된 효과의 스크린샷을 살펴보겠습니다.
두 번째를 계속 업로드하려면 더하기 기호를 클릭하세요. picture#🎜 🎜#
<--引入cropper相关文件--> <link rel="stylesheet" href="/home/style/cropper.css" /> <link href="/home/tupian/css/bootstrap.min.css" rel="stylesheet"> <link href="/home/tupian/css/cropper.min.css" rel="stylesheet"> <link href="/home/tupian/css/main.css" rel="stylesheet"> <script src="/home/tupian/js/jquery.min.js"></script> <script src="/home/tupian/js/bootstrap.min.js"></script> <script src="/home/tupian/js/cropper.min.js"></script> <script src="/home/tupian/js/main.js"></script> <script src="http://www.jq22.com/jquery/jquery-2.1.1.js"></script> <div class="form-group"> <label class="col-sm-3 control-label">照片:</label> <div class="col-sm-9"> <div class="a-up"> <--是第二张图片加号的效果--> <input type="file" onchange="onChangeFn(this); "name="image[]" accept="image/jpeg,image/png" required /> </div> <div class="error">*请添加图片</div> </div> </div> <--模态框--> <div class="modal fade" id="modal" tabindex="-1" role="dialog" aria-labelledby="modalLabel" aria-hidden="true"> <div class="modal-dialog" role="document"> <div class="modal-content"> <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button> <div class="modal-header"> <h5 class="modal-title" id="modalLabel">剪裁图片</h5> </div> <div class="modal-body"> <div class="img-container"> <img id="image" style="max-width:100%;max-height:350px;"><--这里的最大高度一定要设置--> </div> </div> <div class="modal-footer"> <button type="button" class="btn btn-primary" id="crop">Crop</button> </div> </div> </div> </div> function onChangeFn (obj) { var _this=$(obj), _upload=_this.parent(); currentUpload=_upload; // <img src="images/erweima.png" class="upload-img"> //截取开始 var files = obj.files; var done = function (url) { image.src = url; $modal.modal('show'); }; var reader; var file; var url; if (files && files.length > 0) { file = files[0]; if (URL) { done(URL.createObjectURL(file)); } else if (FileReader) { reader = new FileReader(); reader.onload = function (e) { done(reader.result); }; reader.readAsDataURL(file); } } } var image = document.getElementById('image'); var $modal = $('#modal'); var currentUpload; var cropper; $modal.on('shown.bs.modal', function () { cropper = new Cropper(image, { aspectRatio: 16/9, zoomable:true, zoomOnWheel:true, viewMode: 0, }); }).on('hidden.bs.modal', function () { cropper.destroy(); cropper = null; }); document.getElementById('crop').addEventListener('click', function () { var canvas; $modal.modal('hide'); if (cropper) { canvas = cropper.getCroppedCanvas({ width: 800, height: 500, }); // avatar.src = canvas.toDataURL(); <--读取图片--> var reader = new FileReader(); reader.onload = function(evt) { currentUpload.before('<div class="divimg"><img src="' + evt.target.result + '" class="upload-img"><input type="hidden" value="' + evt.target.result + '" name="picc[]"><button type="button" class="close" onclick="closeFun(this,1);"></button></div>'); } canvas.toBlob(function (result) {reader.readAsDataURL(result);},"image/jpeg"); // console.log(canvas); if (currentUpload.next().css('display')=='block') { currentUpload.next().css('display','none') } var strHtml='<div class="a-up"><input type="file" onchange="onChangeFn(this);" name="image[]" accept="image/jpeg,image/png" id="pic" /></div>'; currentUpload.after(strHtml); currentUpload.hide(); } });백엔드 부분: # 🎜🎜#
<--接收过来的是base64的图片,速度较慢,应该是转成blob图片再传给后台,还没做> $base64_image_content = $_POST["picc"]; foreach($base64_image_content as $k=>$v){ $imageName = date("His",time())."_".rand(1111,9999).'.png'; $dir = date('Ymd'); $path = 'uploads/'.$dir; if (!is_dir($path)){ //判断目录是否存在 不存在就创建 mkdir($path,0777,true); } if (strstr($v,",")){ $base64_image_contents = explode(',',$v); $base64_image = $base64_image_contents[1]; $root = $_SERVER['DOCUMENT_ROOT']."/".$path."/". $imageName; $r = file_put_contents($root, base64_decode($base64_image));//返回的是字节数 } $image[] = '/'.$path.'/'. $imageName; } foreach ($image as $kk=>$vv) { $images[] = json_encode($vv, true); } $data["image"] = '['.implode(',',$images).']';rrree# 🎜🎜#요약: 위 내용은 이 글의 전체 내용입니다. 모든 분들의 공부에 도움이 되었으면 좋겠습니다. 더 많은 관련 비디오 튜토리얼을 보려면
php tutorial
을 방문하세요!위 내용은 thinkphp3.2+cropper는 여러 장의 사진 업로드 및 자르기를 구현합니다(코드 예).의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

WeChat 애플릿은 사진 업로드 기능을 구현합니다. 모바일 인터넷의 발전으로 WeChat 애플릿은 사람들의 삶에 없어서는 안될 부분이 되었습니다. WeChat 미니 프로그램은 다양한 애플리케이션 시나리오를 제공할 뿐만 아니라 이미지 업로드 기능을 포함한 개발자 정의 기능도 지원합니다. 이 기사에서는 WeChat 애플릿에서 이미지 업로드 기능을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. 준비 작업 코드 작성을 시작하기 전에 WeChat 개발자 도구를 다운로드하여 설치하고 WeChat 개발자로 등록해야 합니다. 동시에 WeChat도 이해해야 합니다.

CakePHP 프레임워크를 사용하여 이미지 업로드 및 표시를 구현하는 단계 소개: 최신 웹 애플리케이션에서 이미지 업로드 및 표시는 일반적인 기능 요구 사항입니다. CakePHP 프레임워크는 개발자에게 강력한 기능과 편리한 도구를 제공하여 이미지를 쉽고 효율적으로 업로드하고 표시할 수 있도록 해줍니다. 이 글에서는 CakePHP 프레임워크를 사용하여 이미지를 업로드하고 표시하는 방법을 소개합니다. 1단계: 파일 업로드 양식 만들기 먼저 사용자가 이미지를 업로드할 수 있는 보기 파일에 양식을 만들어야 합니다. 다음은 그 예입니다.

Vue 기술 개발에서 이미지 업로드 및 압축을 처리하는 방법 최신 웹 애플리케이션에서 이미지 업로드는 매우 일반적인 요구 사항입니다. 그러나 네트워크 전송 및 저장상의 이유로 고해상도 원본 이미지를 직접 업로드할 경우 업로드 속도가 느려지고 저장 공간이 크게 낭비될 수 있습니다. 따라서 이미지를 업로드하고 압축하는 것은 매우 중요합니다. Vue 기술 개발에서는 기성 솔루션을 사용하여 이미지 업로드 및 압축을 처리할 수 있습니다. 다음은 vue-upload-comone 사용법을 소개합니다.

PHP와 Vue를 사용하여 이미지 업로드 기능을 구현하는 방법 현대 웹 개발에서 이미지 업로드 기능은 매우 일반적인 요구 사항입니다. 이 글에서는 PHP와 Vue를 사용하여 이미지 업로드 기능을 구현하는 방법을 자세히 소개하고 구체적인 코드 예제를 제공합니다. 1. 프론트엔드 부분(Vue) 먼저 프론트엔드에 이미지를 업로드하기 위한 폼을 생성해야 합니다. 구체적인 코드는 다음과 같습니다:<template><div><inputtype="fil

인터넷이 발달하면서 이미지 업로드는 웹사이트와 애플리케이션 개발에 필수적인 기능이 되었습니다. PHP 분야에서 ThinkPHP6은 매우 인기 있는 개발 프레임워크가 되었습니다. 이번 글에서는 ThinkPHP6를 사용하여 이미지 업로드를 구현하는 방법을 소개하겠습니다. 1. 프로젝트 및 컨트롤러 생성 먼저 새로운 ThinkPHP6 프로젝트를 생성해야 합니다. Composer를 사용하여 설치하거나 공식 웹사이트에서 최신 버전을 다운로드할 수 있습니다. 설치가 완료되면 콘솔에 입력하세요.

PHP를 사용하여 간단한 온라인 이미지 업로드 및 표시 시스템을 구현하는 방법 이미지 업로드 및 표시 시스템은 현대 웹사이트에서 일반적으로 사용되는 기능 중 하나입니다. 이 기능은 개발 과정에서 PHP를 사용하여 빠르게 구현할 수 있습니다. 이 기사에서는 PHP를 사용하여 간단한 온라인 이미지 업로드 및 표시 시스템을 작성하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. 데이터베이스 및 테이블 생성 먼저 업로드된 이미지 정보를 저장할 데이터베이스와 테이블을 생성해야 합니다. 다음 SQL 문을 사용하여 "images"라는 테이블을 만들고 설정합니다.

Vue 개발 시 이미지 업로드 미리보기 모달 상자 표시 문제를 해결하는 방법 Vue 개발에서는 이미지를 업로드하고 미리보아야 하는 경우가 종종 있습니다. 이 경우, 이미지를 업로드한 후 모달 상자에 미리보기 이미지를 표시하는 방법에 대한 일반적인 질문이 있습니다. 이 기사에서는 이 문제를 해결하는 방법을 소개합니다. 먼저 업로드할 이미지 파일을 선택하려면 Vue 구성 요소에 파일 업로드 입력 요소를 추가해야 합니다. 파일 업로드의 변경 이벤트를 수신하여 사용자가 선택한 이미지를 얻을 수 있습니다.

Vue 기술 개발에서 이미지 업로드 및 자르기를 구현하는 방법에는 특정 코드 예제가 필요합니다. 최신 웹 개발에서는 이미지 업로드 및 이미지 자르기가 일반적인 요구 사항 중 하나입니다. 널리 사용되는 프런트엔드 프레임워크인 Vue.js는 이러한 기능을 달성하는 데 도움이 되는 풍부한 도구와 플러그인을 제공합니다. 이 글에서는 Vue 기술 개발에서 이미지 업로드 및 자르기를 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 이미지 업로드 구현은 이미지 선택과 이미지 업로드의 두 단계로 나눌 수 있습니다. Vue에서는 타사 플러그인을 사용하여 이를 단순화할 수 있습니다.
