PHP处理bmp格式图片的步骤

白天qa提出项目上传图片有问题,具体为:上传成功,预览失败。我去了之后,又上传了几张其他的图片可以上传,然后仔细问了下他上传的是哪张图片,看了后使用getimagesize函数打印了下。本文主要和大家介绍了php处理bmp格式图片的方法,结合具体实例形式分析了php操作bmp格式图片的相关函数与使用技巧,需要的朋友可以参考下,希望能帮助到大家。

Array(  [0] => 494  [1] => 260  [2] => 6  [3] => width="494" height="260"  [bits] => 24  [mime] => image/x-ms-bmp)

仔细看下,上面打印的数组,mime为image/x-ms-bmp,也就是bmp格式的,印象中php的gd库没有处理这个函数,后来我便在配置文件中,只要mime为这种的便不能上传。

晚上回来后,我便在网上查找php处理bmp相关方法,后来终于在stackoverflow中找到了,帖子里说进入官网的有关imagecreate的函数评论,有个ImageCreateFromBMP方法,先把bmp格式的文件给此函数调用,再用imagejpeg保存就行,后来试了下,发现imagepng也行,下面贴出代码。

<?phpfunction ImageCreateFromBMP($filename) {  //Ouverture du fichier en mode binaire  if (!$f1 = fopen($filename, "rb"))    return FALSE;  //1 : Chargement des ent�tes FICHIER  $FILE = unpack("vfile_type/Vfile_size/Vreserved/Vbitmap_offset", fread($f1, 14));  if ($FILE['file_type'] != 19778)    return FALSE;  //2 : Chargement des ent�tes BMP  $BMP = unpack('Vheader_size/Vwidth/Vheight/vplanes/vbits_per_pixel' .      '/Vcompression/Vsize_bitmap/Vhoriz_resolution' .      '/Vvert_resolution/Vcolors_used/Vcolors_important', fread($f1, 40));  $BMP['colors'] = pow(2, $BMP['bits_per_pixel']);  if ($BMP['size_bitmap'] == 0)    $BMP['size_bitmap'] = $FILE['file_size'] - $FILE['bitmap_offset'];  $BMP['bytes_per_pixel'] = $BMP['bits_per_pixel'] / 8;  $BMP['bytes_per_pixel2'] = ceil($BMP['bytes_per_pixel']);  $BMP['decal'] = ($BMP['width'] * $BMP['bytes_per_pixel'] / 4);  $BMP['decal'] -= floor($BMP['width'] * $BMP['bytes_per_pixel'] / 4);  $BMP['decal'] = 4 - (4 * $BMP['decal']);  if ($BMP['decal'] == 4)    $BMP['decal'] = 0;  //3 : Chargement des couleurs de la palette  $PALETTE = array();  if ($BMP['colors'] = 0) {    $X = 0;    while ($X > 4);        else          $COLOR[1] = ($COLOR[1] & 0x0F);        $COLOR[1] = $PALETTE[$COLOR[1] + 1];      }      elseif ($BMP['bits_per_pixel'] == 1) {        $COLOR = unpack("n", $VIDE . substr($IMG, floor($P), 1));        if (($P * 8) % 8 == 0)          $COLOR[1] = $COLOR[1] >> 7;        elseif (($P * 8) % 8 == 1)          $COLOR[1] = ($COLOR[1] & 0x40) >> 6;        elseif (($P * 8) % 8 == 2)          $COLOR[1] = ($COLOR[1] & 0x20) >> 5;        elseif (($P * 8) % 8 == 3)          $COLOR[1] = ($COLOR[1] & 0x10) >> 4;        elseif (($P * 8) % 8 == 4)          $COLOR[1] = ($COLOR[1] & 0x8) >> 3;        elseif (($P * 8) % 8 == 5)          $COLOR[1] = ($COLOR[1] & 0x4) >> 2;        elseif (($P * 8) % 8 == 6)          $COLOR[1] = ($COLOR[1] & 0x2) >> 1;        elseif (($P * 8) % 8 == 7)          $COLOR[1] = ($COLOR[1] & 0x1);        $COLOR[1] = $PALETTE[$COLOR[1] + 1];      } else        return FALSE;      imagesetpixel($res, $X, $Y, $COLOR[1]);      $X++;      $P += $BMP['bytes_per_pixel'];    }    $Y--;    $P+=$BMP['decal'];  }  //Fermeture du fichier  fclose($f1);  return $res;}$pic = '2.bmp';$res = ImageCreateFromBMP($pic);imagepng($res, '1.png');imagejpeg($res, '1.jpeg');

相关推荐:

bmp格式图片 php 将bmp图片转为jpg等其他任意格式的图片

立即学习“PHP免费学习笔记(深入)”;

[GD]生成bmp格式的图片(imagebmp)

[GD]生成bmp格式的图片_PHP

以上就是PHP处理bmp格式图片的步骤的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1545798.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 17:27:16
下一篇 2025年12月21日 17:27:32

相关推荐

  • 使用CI框架向网页引入CSS样式的步骤

    CI框架引入CSS样式的步骤,需要具体代码示例 CI(CodeIgniter)框架是一种流行的PHP开发框架,被广泛用于构建高效的Web应用程序。在开发Web应用程序时,美观的用户界面是一个重要的考虑因素。使用CSS样式可以达到对Web应用程序界面的优化和个性化,让用户获得更好的体验。在CI框架中,…

    2025年12月24日
    000
  • 逐步掌握常用的CSS基础选择器

    了解CSS代码基本选择器:一步步掌握常用选择器 在HTML和CSS中,选择器是用来选择元素并应用样式的重要工具。了解和熟练使用CSS代码中的基本选择器是成为优秀前端开发人员的基本要求之一。本文将逐步介绍CSS代码中的常用选择器,帮助读者掌握选择器的基本用法和使用技巧。 元素选择器最基本的选择器就是元…

    2025年12月24日
    000
  • 如何使用CSS实现图片的旋转效果

    如何使用CSS实现图片的旋转效果 CSS(Cascading Style Sheets)是一种用于设置网页样式和布局的标记语言。通过CSS,我们可以实现许多吸引人的网页效果,其中包括图片的旋转效果。在本文中,我们将讨论如何使用CSS来实现图片的旋转效果,并提供一些具体的代码示例。 在CSS中,我们可…

    2025年12月24日
    000
  • 如何通过纯CSS实现图片的模糊放大效果的方法和技巧

    如何通过纯CSS实现图片的模糊放大效果的方法和技巧 摘要:通过纯CSS实现图片的模糊放大效果可以为网页增加更具吸引力的视觉效果。本文将介绍一种简单的方法和一些技巧,包括具体的代码示例。 一、背景知识在介绍实现方法之前,我们先来了解一些背景知识。CSS中有一个滤镜(filter)属性,可以对元素应用各…

    2025年12月24日
    000
  • 如何通过纯CSS实现图片的3D立体旋转效果的方法和技巧

    如何通过纯CSS实现图片的3D立体旋转效果的方法和技巧,需要具体代码示例 随着Web技术的发展,我们可以通过CSS实现各种令人惊叹的效果,其中包括图片的3D立体旋转效果。本文将介绍如何通过纯CSS实现这样的效果,并提供具体的代码示例,帮助读者轻松掌握技巧。 要实现图片的3D立体旋转效果,我们需要利用…

    好文分享 2025年12月24日
    000
  • 如何通过纯CSS实现图片的放大缩小效果的方法和技巧

    如何通过纯CSS实现图片的放大缩小效果的方法和技巧 在现代的网页设计中,图片的展示和处理是非常重要的一部分。而图片的放大缩小效果可以为网站的视觉呈现增添趣味和交互性。在这篇文章中,我们将介绍如何通过纯CSS实现图片的放大缩小效果,并提供具体的代码示例。 使用transition属性实现平滑的过渡效果…

    2025年12月24日
    000
  • 如何通过纯CSS实现图片的立方体转动效果的方法和技巧

    如何通过纯CSS实现图片的立方体转动效果的方法和技巧 在现代网页设计中,添加一些炫酷的效果是非常重要的,而利用CSS实现立方体转动效果是一个非常有趣而具有挑战性的任务。本文将介绍一种通过纯CSS实现图片的立方体转动效果的方法和技巧,并提供一些具体的代码示例。 首先,我们需要一个基本的HTML结构,包…

    2025年12月24日 好文分享
    000
  • 如何通过纯CSS实现图片的旋转平移效果的方法和技巧

    如何通过纯CSS实现图片的旋转平移效果的方法和技巧 在现代web设计中,动画效果已经成为了吸引用户注意力和提升用户体验的重要组成部分。而图片的旋转平移效果是其中一个较为常见的动画效果。在本文中,我将介绍如何通过纯CSS来实现这个效果,并提供具体的代码示例。让我们一起来学习吧! 首先,我们需要一个HT…

    2025年12月24日
    000
  • 如何通过纯CSS实现图片的翻转效果的方法和技巧

    如何通过纯CSS实现图片的翻转效果的方法和技巧 前言:在Web开发中,我们经常需要为网页添加一些动画效果来增加用户体验。图片的翻转效果是其中一个常见的效果之一。通过纯CSS来实现图片的翻转不仅简单方便,还可以避免使用JavaScript等其他语言带来的额外开销。本文将介绍如何通过纯CSS实现图片的翻…

    2025年12月24日
    000
  • 如何使用CSS制作镂空效果的图片

    如何使用CSS制作镂空效果的图片 在网页设计中,如何制作出独特、有吸引力的效果是一个不断探索的问题。其中,镂空效果是一种常见而又常用的技巧之一。通过使用CSS,我们可以实现为图片添加镂空的效果,从而提升页面的美观程度和吸引力。 下面,我们将详细介绍如何使用CSS制作镂空效果的图片,并提供具体代码示例…

    2025年12月24日
    000
  • css3怎么将彩色图片改为黑白色图片

    在css3中,可以利用filter属性来将彩色图片改为黑白色图片,只需要设置该属性的值为“grayscale(%)”即可,具体语法格式“img{filter:grayscale(100%)}”。 本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。 在…

    2025年12月24日
    000
  • css图片怎么变圆

    在css中,可以利用border-radius属性来让图片变圆,只需要给img元素添加“border-radius: 50%;”样式即可。border-radius属性可以给元素设置圆角边框,圆角的半径不能超过宽/高的一半。 本教程操作环境:windows7系统、CSS3&&HTML…

    2025年12月24日 好文分享
    000
  • 网页设计css样式代码大全,快来收藏吧!

    减少很多不必要的代码,html+css可以很方便的进行网页的排版布局。小伙伴们收藏好哦~ 一.文本设置    1、font-size: 字号参数  2、font-style: 字体格式 3、font-weight: 字体粗细 4、颜色属性 立即学习“前端免费学习笔记(深入)”; color: 参数 …

    2025年12月24日
    000
  • css中id选择器和class选择器有何不同

    之前的文章《什么是CSS语法?详细介绍使用方法及规则》中带了解CSS语法使用方法及规则。下面本篇文章来带大家了解一下CSS中的id选择器与class选择器,介绍一下它们的区别,快来一起学习吧!! id选择器和class选择器介绍 CSS中对html元素的样式进行控制是通过CSS选择器来完成的,最常用…

    2025年12月24日
    000
  • css如何改变图片的背景

    css改变图片的背景的方法是,添加background-image属性,并且将属性值设置为你想要的图片的url地址,例如【background-image:url(‘../images/mix/paper.gif’);】。 本文操作环境:windows10系统、css 3、t…

    2025年12月24日
    000
  • css如何设置图片不平铺

    css设置图片不平铺的方法是使用【background-repeat】属性设置图片不平铺,其中【no-repeat】为不平铺,即只显示一次。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 css设置图片不平铺的方法: css可以使用background-repeat属性设置…

    2025年12月24日
    000
  • css中怎么把图片设置居右

    在css中,可以使用text-align属性把图片设置居右,只需要给图片元素设置“text-align:right;”即可。text-align属性指定元素文本的水平对齐方式,当值为right时,表示该元素排列到右边。 本教程操作环境:windows7系统、CSS3&&HTML5版、…

    2025年12月24日
    000
  • css中的图片翻转属性是什么

    css中的图片翻转属性是transform。transform属性应用于元素的2D或3D转换,可以利用该属性对元素进行旋转、移动、倾斜等操作,语法“transform: none|transform-functions;”;transform支持的翻转函数有rotate()、rotate3d()、r…

    2025年12月24日
    000
  • css怎么设置图片位置居中

    css设置图片位置居中的方法:可以在图片外面添加一个p标签,然后通过设置line-height属性使图片位置居中,如【 line-height:300px;】。 本文操作环境:windows10系统、css 3、thinkpad t480电脑。 具体方法如下: 1、利用display:table-c…

    2025年12月24日 好文分享
    000
  • css怎么实现图片半透明效果

    css实现图片半透明效果的方法:可以通过opacity属性来进行设置,如【style=”-moz-opacity:0.5″;】。opacity属性用来设置元素的不透明级别,语法为【opacity:value|inherit;】。 本文环境: windows10、css3 适用…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信