php 能否制作图形,PHP制作 3D图形之自定义图形及矢量图[多图]

PHP制作

3D图形之自定义图形及矢量图[多图]

2009-11-6 19:52:08   出处:https://www.yqdown.com

上一篇执行

了一些基本

3D图形实例,本篇介绍自定义及矢量图实例。首先打造

一个三尖角星体,分别由“前面”,“后面”和三个“侧面”组成。

自定义多边形

代码:

以下为引用的内容:

require_once('Image/3D.php');

$image = new Image_3D();

$image->setColor(new Image_3D_Color(255, 255, 255));

//建立

光源

$light1 = $image->createLight('light',array(-50, -50, -50));

$light1->setColor(new Image_3D_Color(100, 250, 100));

$light2 = $image->createLight('light',array(50, -50, 0));

$light2->setColor(new Image_3D_Color(100, 100, 250));

$light3 = $image->createLight('light',array(50, 50, 0));

$light3->setColor(new Image_3D_Color(50, 0, 100));

//建立

多边形数组

$polygons = array();

//前面点坐标

$polygons[] = array(

array(0, -120, 0), array(-18, -12, 0),

array(-86, 48, 0), array(0, 18, 0),

array(86, 48, 0), array(18, -12, 0)

);

//后面点坐标

$polygons[] = array(

array(0, -120, 60), array(-18, -12, 60),

array(-86, 48, 60), array(0, 18, 60),

array(86, 48, 60), array(18, -12, 60)

);

//三侧面点坐标

$polygons[] = array(

array(0, -120, 0), array(-18, -12, 0),

array(-86, 48, 0), array(-86, 48, 60),

array(-18, -12, 60),array(0, -120, 60)

);

$polygons[] = array(

array(-86, 48, 0), array(0, 18, 0),

array(86, 48, 0), array(86, 48, 60),

array(0, 18, 60), array(-86, 48, 60)

);

$polygons[] = array(

array(86, 48, 0), array(18, -12, 0),

array(0, -120, 0), array(0, -120, 60),

array(18, -12, 60),array(86, 48, 60)

);

//打造

3D图像

foreach ($polygons as $poly) {

$points = array();

foreach ($poly as $set) {

$points[] = new Image_3D_Point($set[0], $set[1], $set[2]);

}

$p = $image->createObject('polygon', $points);

$p->setColor(new Image_3D_Color(255, 255, 255));

}

$image->transform($image->createMatrix('Rotation', array(-10, -25, -15)));

$image->createRenderer('perspectively');

$image->createDriver('gd');

$image->render(300, 300, 'http://www.qqread.com/php/2009/08/http://www.qqread.com/php/2009/08/anim.png');

echo 'anim.png';

?>

效果图:

20091161952720550.jpg

矢量图

可缩放的矢量图形(Scalable Vector Graphics,SVG)文件格式是组成2D图像的矢量XML文件。 在2001年,W3C对该格式执行

了标准化,但其在Web方面的运用

因为阅读

器显示SVG文件的牵制而不很流行。 目前,最好的选择是Firefox它有内置的SVG支持,或具有Adobe SVG插件的IE。下面通过一个实例生成SVG文件。

代码:

以下为引用的内容:

require_once('Image/3D.php');

$rot_x = 45;

$rot_y = 45;

$rot_z = 10;

$image = new Image_3D();

$image->setColor(new Image_3D_Color(255, 255, 255));

for ($x=0; $x < 4; $x++) {

for ($y=0; $y < 4; $y++) {

for ($z=0; $z < 4; $z++) {

//建立

球体

$sphere = $image->createObject('sphere', array('r' => 25, 'detail' => 3));

//后面150用于配置

图像透明度

$sphere->setColor(new Image_3D_Color(255, 162, 0, 150));

$sphere->transform($image->createMatrix('Move', array(($x * 75) + 50, $y * 75, $z * 75)));

$sphere->transform($image->createMatrix('Rotation', array($rot_x, $rot_y, $rot_z)));

}

}

}

$image->transform($image->createMatrix('Move', array(-225, -100, 0)));

$image->createRenderer('perspectively');

//运用

SVG驱动生成矢量图

$image->createDriver('svg');

$image->render(600, 600, 'anim.svg');

header('Location:anim.svg');

?>

效果图:

20091161952817533.jpg

输出的SVG文件打开后,其格式即为XML:

以下为引用的内容:

/p>

"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">

style="fill: #ffffff; fill-opacity: 1.00; stroke: none;" />

style="fill: #ffa200; fill-opacity: 0.41; stroke: none;" />

style="fill: #ffa200; fill-opacity: 0.41; stroke: none;" />

... ...

style="fill: #ffa200; fill-opacity: 0.41; stroke: none;" />

style="fill: #ffa200; fill-opacity: 0.41; stroke: none;" />

作者: Gnie出处: {GnieTech} (http://www.cnblogs.com/gnielee/) 版权声明: 本文的版权归作者与博客园共有。转载时须注明本文的细致

链接,否则作者将保留追究其法律责任。

分享到

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值