设为首页 收藏本站
查看: 975|回复: 0

[经验分享] PHP绘制3D图形 之 自定义图形及矢量图

[复制链接]

尚未签到

发表于 2015-8-24 15:30:48 | 显示全部楼层 |阅读模式
  上一篇进行了一些简单3D图形实例,本篇介绍自定义及矢量图实例。首先绘制一个三尖角星体,分别由“前面”,“后面”和三个“侧面”组成。

自定义多边形
  
  代码:
<?php
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, 'anim.png');
echo '<img src="anim.png">';
?>
  效果图:
DSC0000.png

矢量图
  可缩放的矢量图形(Scalable Vector Graphics,SVG)文件格式是组成2D图像的矢量XML文件。 在2001年,W3C对该格式进行了标准化,但其在Web方面的使用因为浏览器显示SVG文件的牵制而不很流行。 目前,最好的选择是Firefox它有内置的SVG支持,或具有Adobe SVG插件的IE。下面通过一个实例生成SVG文件。
  代码:
<?php
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');
?>
  效果图:
DSC0001.jpg
  输出的SVG文件打开后,其格式即为XML:
<?xml version="1.0" ?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN"
"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg xmlns="http://www.w3.org/2000/svg" x="0" y="0" width="600" height="600">
<defs id="defs16387">
</defs>
<polygon id="background1" points="0,0 600,0 600,600 0,600"
style="fill: #ffffff; fill-opacity: 1.00; stroke: none;" />
<polygon points="325.87,264.90 323.53,258.51 321.87,262.52"
style="fill: #ffa200; fill-opacity: 0.41; stroke: none;" />
<polygon points="319.40,256.07 321.87,262.52 323.53,258.51"
style="fill: #ffa200; fill-opacity: 0.41; stroke: none;" />
... ...
<polygon points="230.72,174.08 236.47,190.12 226.95,185.47"
style="fill: #ffa200; fill-opacity: 0.41; stroke: none;" />
<polygon points="230.72,174.08 252.69,180.70 236.47,190.12"
style="fill: #ffa200; fill-opacity: 0.41; stroke: none;" />
</svg>
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-103624-1-1.html 上篇帖子: android,与PHP通信,返回JSON 下篇帖子: [转载]敏感词过滤,PHP实现的Trie树
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表