让我们先描述一下任务:
我想创建一个网页,其中包含几行文本和一个小的(比方说100 x 20像素)图形。每个图形都是动态生成的(因此每次加载页面时它都是新图形。)
我能想象的唯一方法就是每次指示行时在服务器上创建一个新的PNG文件,并包含指向HTML的新创建文件的链接:<img src='row1graph.png'>
。
如果页面是单个图像 - 我可以直接将其输出到浏览器,但这不是我的情况。
所以问题是:有没有更好的方法来处理这些图像并跳过不必要的磁盘访问操作?
答案 0 :(得分:2)
你可以从PHP而不是从文件提供图像 - 我的意思是你可以让PHP动态创建一个图像并提供它,而不是必须在你的web服务器的文件系统中有一个文件,并且必须在名称中引用它。 HTML中标记的src字段。
所以,而不是
<image src="xyz.png" alt="..." size="...">
你可以使用
<img src="/php/thumb.php?param1=128¶m2=45"/>
导致在呈现页面时调用/php/thumb.php
处的PHP脚本。在该脚本中,您可以动态创建图像(如果您愿意,可以使用额外的参数),如下所示:
<?php
header("Content-type: image/png");
$p1 = $_GET['param1'];
$p2 = $_GET['param2'];
// Create a 200x200 image
$im = imagecreatetruecolor(200,200);
$white = imagecolorallocate($im, 255, 255, 255);
$red = imagecolorallocate($im, 255, 0, 0);
// Here you can draw in the image, write on it, set any pixels, calculate any colours you wish
// Draw a white rectangle, then a red one
imagefilledrectangle($im, 50, 50, 100, 100, $white);
imagefilledrectangle($im, 75, 75, 150, 150, $red);
imagepng($im);
imagedestroy($im);
?>
我在前3行之后省略了一些代码,所以你只看到了技术而不是我代码的所有细节。您感兴趣的实际行是:
header(...image/png);
告诉浏览器什么类型的东西即将来临 - 即图像和
imagepng();
实际上将PNG数据流发送到浏览器。
上面的代码在浏览器中生成:
答案 1 :(得分:1)
有两种方法可以优化网页中的小图形。您可以使用图块集概念(单个图像中的所有图形,基于例如背景位置的偏移),或者您可以将PNG直接嵌入到页面中作为base-64:
<img alt="Embedded Image" src="" />
根据文件大小和浏览器支持,这些选项具有不同的优点。当然,两者都可以组合在一起 - 您可以使用嵌入式磁贴集。
答案 2 :(得分:1)
好吧,如果你想避免&#34;不必要的磁盘访问&#34;由于图像尺寸很小,您可以使用Base64 encoding。您也可以将编码的字符串存储在数据库中。
这种方式<img src='row1graph.png'>
变成......
<img src=""/>
&#13;