赵祖辉 图片上传类;支持水印-日期文件夹-生成缩略图 ,支持多文件上传,

本文介绍了一个PHP类,用于处理多文件上传、生成缩略图及添加水印等功能。支持按日期生成目录,并通过简单的配置实现多种图片处理需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1 <?php
2 /*
3 图片上传类; joffe :mailto:gclinux@163.com 欢迎改进
4 版本:2011-12-26 beta;
5 本类支持多文件上传,图片生成略缩图,加水印,按日期生成目录的基本功能
6 调用例子:
7 控制器代码:
8 <?php
9 if ($_GET['action'] == 'save') {
10 $up = new upload(); //创建
11 $up->set_dir(dirname(__FILE__).'/upload/','{y}/{m}'); //保存路径,支持{y}{m}{d}这几个选项
12 $up->set_thumb(100,80); //缩略图大小设置.单位为像素
13 $up->set_watermark(dirname(__FILE__).'/jblog/images/watermark.png',6,90); //水印设置
14 $fs = $up->execute(); //开始执行
15
16 var_dump($fs); //测试用 查看类的情况
17 }
18 ?>
19 /////视图表单---------
20 <html>
21 <head><title>test</title></head>
22 <body style="margin:0;padding:0″>
23 <form name="upload" method="post" action="?action=save" enctype="multipart/form-data" style="margin:0″>
24 <input type="file" name="attach[]" />
25 <input type="file" name="attach[]" /> //支持多张图片上传
26 <input type="submit" name="submit" value="上 传" />
27 </form>
28 </body>
29 </html>
30
31 */
32 class upload {
33
34 var $dir; //附件存放物理目录
35 var $time; //自定义文件上传时间
36 var $allow_types; //允许上传附件类型
37 var $field; //上传控件名称
38 var $maxsize; //最大允许文件大小,单位为KB
39
40 var $thumb_width; //缩略图宽度
41 var $thumb_height; //缩略图高度
42
43 var $watermark_file; //水印图片地址
44 var $watermark_pos; //水印位置
45 var $watermark_trans;//水印透明度
46
47
48 //构造函数
49 //$types : 允许上传的文件类型 , $maxsize : 允许大小 , $field : 上传控件名称 , $time : 自定义上传时间
50 function upload($types = 'jpg|png', $maxsize = 1024, $field = 'attach', $time = '') {
51 $this->allow_types = explode('|',$types);
52 $this->maxsize = $maxsize * 1024;
53 $this->field = $field;
54 $this->time = $time ? $time : time();
55 }
56
57 //设置并创建文件具体存放的目录
58 //$basedir : 基目录,必须为物理路径
59 //$filedir : 自定义子目录,可用参数{y}、{m}、{d}
60 function set_dir($basedir,$filedir = '') {
61 $dir = $basedir;
62 !is_dir($dir) && @mkdir($dir,0777);
63 if (!empty($filedir)) {
64 $filedir = str_replace(array('{y}','{m}','{d}'),array(date('Y',$this->time),date('m',$this->time),date('d',$this->time)),strtolower($filedir));//用string_replace把{y} {m} {d}几个标签进行替换
65 $dirs = explode('/',$filedir);
66 foreach ($dirs as $d) {
67 !empty($d) && $dir .= $d.'/';
68 !is_dir($dir) && @mkdir($dir,0777);
69 }
70 }
71 $this->dir = $dir;
72 }
73
74 //图片缩略图设置,如果不生成缩略图则不用设置
75 //$width : 缩略图宽度 , $height : 缩略图高度
76 function set_thumb ($width = 0, $height = 0) {
77 $this->thumb_width = $width;
78 $this->thumb_height = $height;
79 }
80
81 //图片水印设置,如果不生成添加水印则不用设置
82 //$file : 水印图片 , $pos : 水印位置 , $trans : 水印透明度
83 function set_watermark ($file, $pos = 6, $trans = 80) {
84 $this->watermark_file = $file;
85 $this->watermark_pos = $pos;
86 $this->watermark_trans = $trans;
87 }
88
89 /*—————————————————————-
90 执行文件上传,处理完返回一个包含上传成功或失败的文件信息数组,
91 其中:name 为文件名,上传成功时是上传到服务器上的文件名,上传失败则是本地的文件名
92 dir 为服务器上存放该附件的物理路径,上传失败不存在该值
93 size 为附件大小,上传失败不存在该值
94 flag 为状态标识,1表示成功,-1表示文件类型不允许,-2表示文件大小超出
95 —————————————————————–*/
96 function execute() {
97 $files = array(); //成功上传的文件信息
98 $field = $this->field;
99 $keys = array_keys($_FILES[$field]['name']);
100 foreach ($keys as $key) {
101 if (!$_FILES[$field]['name'][$key]) continue;
102
103 $fileext = $this->fileext($_FILES[$field]['name'][$key]); //获取文件扩展名
104 $filename = date('Ymdhis',$this->time).mt_rand(10,99).'.'.$fileext; //生成文件名
105 $filedir = $this->dir; //附件实际存放目录
106 $filesize = $_FILES[$field]['size'][$key]; //文件大小
107
108 //文件类型不允许
109 if (!in_array($fileext,$this->allow_types)) {
110 $files[$key]['name'] = $_FILES[$field]['name'][$key];
111 $files[$key]['flag'] = -1;
112 continue;
113 }
114
115 //文件大小超出
116 if ($filesize > $this->maxsize) {
117 $files[$key]['name'] = $_FILES[$field]['name'][$key];
118 $files[$key]['name'] = $filesize;
119 $files[$key]['flag'] = -2;
120 continue;
121 }
122
123 $files[$key]['name'] = $filename;
124 $files[$key]['dir'] = $filedir;
125 $files[$key]['size'] = $filesize;
126
127 //保存上传文件并删除临时文件
128 if (is_uploaded_file($_FILES[$field]['tmp_name'][$key])) {
129 move_uploaded_file($_FILES[$field]['tmp_name'][$key],$filedir.$filename);
130 @unlink($_FILES[$field]['tmp_name'][$key]);
131 $files[$key]['flag'] = 1;
132
133 //对图片进行加水印和生成缩略图,这里演示只支持jpg和png(gif生成的话会没了帧的)
134 if (in_array($fileext,array('jpg','png'))) {
135 if ($this->thumb_width) {
136 if ($this->create_thumb($filedir.$filename,$filedir.'thumb_'.$filename)) {
137 $files[$key]['thumb'] = 'thumb_'.$filename; //缩略图文件名
138 }
139 }
140 $this->create_watermark($filedir.$filename);
141 }
142 }
143 }
144
145 return $files;
146 }
147
148 //创建缩略图,以相同的扩展名生成缩略图
149 //$src_file : 来源图像路径 , $thumb_file : 缩略图路径
150 function create_thumb ($src_file,$thumb_file) {
151 $t_width = $this->thumb_width;
152 $t_height = $this->thumb_height;
153
154 if (!file_exists($src_file)) return false;
155
156 $src_info = getImageSize($src_file);
157
158 //如果来源图像小于或等于缩略图则拷贝源图像作为缩略图,免去操作
159 if ($src_info[0] <= $t_width && $src_info[1] <= $t_height) {
160 if (!copy($src_file,$thumb_file)) {
161 return false;
162 }
163 return true;
164 }
165
166 //按比例计算缩略图大小
167 if (($src_info[0]-$t_width) > ($src_info[1]-$t_height)) {
168 $t_height = ($t_width / $src_info[0]) * $src_info[1];
169 } else {
170 $t_width = ($t_height / $src_info[1]) * $src_info[0];
171 }
172
173 //取得文件扩展名
174 $fileext = $this->fileext($src_file);
175
176 switch ($fileext) {
177 case 'jpg' :
178 $src_img = ImageCreateFromJPEG($src_file); break;
179 case 'png' :
180 $src_img = ImageCreateFromPNG($src_file); break;
181 case 'gif' :
182 $src_img = ImageCreateFromGIF($src_file); break;
183 }
184
185 //创建一个真彩色的缩略图像
186 $thumb_img = @ImageCreateTrueColor($t_width,$t_height);
187
188 //ImageCopyResampled函数拷贝的图像平滑度较好,优先考虑
189 if (function_exists('imagecopyresampled')) {
190 @ImageCopyResampled($thumb_img,$src_img,0,0,0,0,$t_width,$t_height,$src_info[0],$src_info[1]);
191 } else {
192 @ImageCopyResized($thumb_img,$src_img,0,0,0,0,$t_width,$t_height,$src_info[0],$src_info[1]);
193 }
194
195 //生成缩略图
196 switch ($fileext) {
197 case 'jpg' :
198 ImageJPEG($thumb_img,$thumb_file); break;
199 case 'gif' :
200 ImageGIF($thumb_img,$thumb_file); break;
201 case 'png' :
202 ImagePNG($thumb_img,$thumb_file); break;
203 }
204
205 //销毁临时图像
206 @ImageDestroy($src_img);
207 @ImageDestroy($thumb_img);
208
209 return true;
210
211 }
212
213 //为图片添加水印
214 //$file : 要添加水印的文件
215 function create_watermark ($file) {
216
217 //文件不存在则返回
218 if (!file_exists($this->watermark_file) || !file_exists($file)) return;
219 if (!function_exists('getImageSize')) return;
220
221 //检查GD支持的文件类型
222 $gd_allow_types = array();
223 if (function_exists('ImageCreateFromGIF')) $gd_allow_types['image/gif'] = 'ImageCreateFromGIF';
224 if (function_exists('ImageCreateFromPNG')) $gd_allow_types['image/png'] = 'ImageCreateFromPNG';
225 if (function_exists('ImageCreateFromJPEG')) $gd_allow_types['image/jpeg'] = 'ImageCreateFromJPEG';
226
227 //获取文件信息
228 $fileinfo = getImageSize($file);
229 $wminfo = getImageSize($this->watermark_file);
230
231 if ($fileinfo[0] < $wminfo[0] || $fileinfo[1] < $wminfo[1]) return;
232
233 if (array_key_exists($fileinfo['mime'],$gd_allow_types)) {
234 if (array_key_exists($wminfo['mime'],$gd_allow_types)) {
235
236 //从文件创建图像
237 $temp = $gd_allow_types[$fileinfo['mime']]($file);
238 $temp_wm = $gd_allow_types[$wminfo['mime']]($this->watermark_file);
239
240 //水印位置
241 switch ($this->watermark_pos) {
242 case 1 : //顶部居左
243 $dst_x = 0; $dst_y = 0; break;
244 case 2 : //顶部居中
245 $dst_x = ($fileinfo[0] - $wminfo[0])/2; $dst_y = 0; break;
246 case 3 : //顶部居右
247 $dst_x = $fileinfo[0]; $dst_y = 0; break;
248 case 4 : //底部居左
249 $dst_x = 0; $dst_y = $fileinfo[1]; break;
250 case 5 : //底部居中
251 $dst_x = ($fileinfo[0] - $wminfo[0]) / 2; $dst_y = $fileinfo[1]; break;
252 case 6 : //底部居右
253 $dst_x = $fileinfo[0]-$wminfo[0]; $dst_y = $fileinfo[1]-$wminfo[1]; break;
254 default : //随机
255 $dst_x = mt_rand(0,$fileinfo[0]-$wminfo[0]); $dst_y = mt_rand(0,$fileinfo[1]-$wminfo[1]);
256 }
257
258 if (function_exists('ImageAlphaBlending')) ImageAlphaBlending($temp_wm,True); //设定图像的混色模式
259 if (function_exists('ImageSaveAlpha')) ImageSaveAlpha($temp_wm,True); //保存完整的 alpha 通道信息
260
261 //为图像添加水印
262 if (function_exists('imageCopyMerge')) {
263 ImageCopyMerge($temp,$temp_wm,$dst_x,$dst_y,0,0,$wminfo[0],$wminfo[1],$this->watermark_trans);
264 } else {
265 ImageCopyMerge($temp,$temp_wm,$dst_x,$dst_y,0,0,$wminfo[0],$wminfo[1]);
266 }
267
268 //保存图片
269 switch ($fileinfo['mime']) {
270 case 'image/jpeg' :
271 @imageJPEG($temp,$file);
272 break;
273 case 'image/png' :
274 @imagePNG($temp,$file);
275 break;
276 case 'image/gif' :
277 @imageGIF($temp,$file);
278 break;
279 }
280 //销毁零时图像
281 @imageDestroy($temp);
282 @imageDestroy($temp_wm);
283 }
284 }
285 }
286
287 //获取文件扩展名
288 function fileext($filename) {
289 return strtolower(substr(strrchr($filename,'.'),1,10));
290 }
291 }
292 ?>
内容概要:该论文研究了激光照射下生物组织内的非傅里叶导热现象,采用双相位滞后生物传热模型(DPL模型)进行分析,并与Pennes模型、热波模型进行了比较。研究表明,当热流延迟时间和温度延迟时间较小时,DPL模型接近传统傅里叶热传导;当热流延迟时间增加时,表现出更多的热波效应。通过数值模拟分析了不同参数下组织的温度分布,结果表明DPL模型能更准确地描述激光与生物组织的热相互作用,对激光临床治疗具有理论指导意义。论文还通过代码实现了DPL模型的数值求解,并比较了三种模型的温度响应差异,分析了不同延迟时间对温度分布的影响,提出了模型选择指导和临床应用建议。 适合人群:具备一定物理学、生物学和编程基础的科研人员、医学工程技术人员以及对激光生物效应感兴趣的学者。 使用场景及目标:①用于研究激光辐照生物组织的热效应;②为激光临床治疗提供理论支持和技术参考;③帮助研究人员理解不同传热模型的特点及其适用场景;④为精确的激光手术规划提供模型选择依据。 其他说明:论文不仅提供了详细的理论分析,还给出了完整的Python代码实现,便于读者复现研究结果。此外,论文还讨论了不同延迟时间对温度分布的具体影响,为激光治疗参数优化提供了理论依据。未来研究方向包括多参数耦合条件下的DPL模型优化、不同组织型的参数数据库建立等。
《DPD_sim_DPD_数字预失真_DPDmatlab_matlab_预失真_源码.zip》这个压缩包文件包含的是关于数字预失真(Digital Predistortion, DPD)技术的MATLAB源码。DPD是通信系统中一个重要的信号处理技术,主要应用于射频功率放大器(RF Power Amplifier, PA)中,以提高放大器的效率和线性度。本文将详细介绍DPD的基本原理、应用以及MATLAB在实现DPD算法中的关键步骤。 1. 数字预失真技术简介: 数字预失真是一种非线性补偿技术,其基本思想是在信号进入功率放大器之前,通过预设的非线性函数对信号进行逆操作,以抵消放大器在高功率输出时产生的非线性失真。这样可以确保放大后的信号尽可能接近原始输入信号,从而提高系统的线性度和频谱效率。 2. DPD工作原理: DPD的核心是建立一个模型来描述PA的非线性特性,通常采用多项式模型或记忆效应模型。模型参数通过实际PA的测量数据来确定,这一步称为系统校准。一旦模型建立,就可以用该模型对输入信号进行预失真处理。 3. MATLAB在DPD实现中的作用: MATLAB是一种强大的数学计算和数据分析工具,广泛用于信号处理和通信领域的仿真。在DPD中,MATLAB可以用来: - 建立和优化DPD模型:使用MATLAB的曲线拟合工具或自定义算法来拟合PA的非线性特性。 - 实现预失真算法:编程实现预失真器,根据模型对输入信号进行预失真处理。 - 仿真验证:通过仿真比较预失真后的信号与未处理信号,评估DPD的效果。 - 实时系统集成:MATLAB代码可以转换为C/C++,方便嵌入到硬件系统中。 4. DPD的实现步骤: - 数据采集:测量PA在不同输入功率下的输出,获取非线性特性数据。 - 模型选择与参数估计:根据数据选择合适的模型(如多项式模型、LUT模型等),并估计模型参数。 - 预失真器设计:编写MATLAB代码实现预失真算法,通常包括输入信号的预处理、模型运算和输出信号的后处理。 - 仿真与优化:通过MATLAB进行系统仿真,调整模型参数和预失真算法,以达到最佳性能。 - 硬件集成:将MATLAB代码转换为可执行的嵌入式代码,集成到实际的通信系统中。 5. MATLAB源码解析: 由于未提供具体的源码细节,无法深入解析。但一般来说,源码可能包括以下几个部分: - 数据处理模块:读取PA的测量数据,进行预处理。 - 模型建立模块:实现模型选择和参数估计。 - 预失真运算模块:根据模型进行预失真计算。 - 仿真与结果显示模块:展示预失真效果,并可能包括性能指标的计算。 DPD_sim_DPD_数字预失真_DPDmatlab_matlab_预失真_源码.zip这个压缩包文件包含了实现数字预失真技术的MATLAB源码,对于理解和研究DPD技术,以及在实际通信系统中应用DPD具有很高的价值。通过深入学习和分析这些源码,我们可以更深入地理解DPD的工作机制,并将其应用到实际项目中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值