? ? PEAR提供了Image_3D Package來創建3D圖像。圖像或光線在3D空間中按照X、Y 、Z 坐標定位。生成的圖像將呈現在2D空間中,可以存儲為 PNG、SVG 格式,或輸出到Shell。通過Image_3D可以很方便生成一些簡單的3D對象,例如立方體、錐體、球體、文本和餅圖。查了一下PEAR文檔關于Image_3D的實例一個也沒有~囧~,只好自己研究一下,將經驗分享給大家,請多多拍磚。言歸正傳,Image_3D需要PEAR和GD(配置php.ini)的支持。
1. 安裝Image_3D
下載Image_3D Package ,目前最新版本為:0.4.1?alpha
?
官方下載:http://pear.php.net/package/Image_3D/download
將壓縮包放到有pear.bat的目錄中,例如:c:\php,若是WAMP5的話則為c:\wamp\php。
執行?pear install Image_3D-0.4.1.gz? 安裝Package:
安裝完畢,Image_3D會在?C:\wamp\php\PEAR\Image?目錄中。
?
2. 3D坐標系
Image_3D的坐標系及旋轉請參考下圖,用于縮放、旋轉或移動物體:
3. 繪制圓錐體
代碼如下:
<?php //調用3D圖形類 require_once('Image/3D.php');//創建一個三維空間 $image = new Image_3D(); $image->setColor(new Image_3D_Color(255, 255, 255));//在坐標系左下方創建一個紅色光點 $light1 = $image->createLight("Light",array(-100, 100, -100)); $light1->setColor(new Image_3D_Color(255, 0, 0));//在坐標系右上方創建一個綠色光點 $light2 = $image->createLight("Light",array(100, -200, -50)); $light2->setColor(new Image_3D_Color(0, 200, 0));//創建3D圓錐體 $cone = $image->createObject('cone',array('detail'=>360)); $cone->setColor(new Image_3D_Color(255, 255, 255)); //按X,Y,Z軸縮放 $cone->transform($image->createMatrix('scale', array(80, 150, 80))); //按X,Y,Z軸旋轉 $cone->transform($image->createMatrix('rotation', array(15, 0, 20))); //按X,Y,Z軸移動 $cone->transform($image->createMatrix('move', array(0, -50, 0)));//創建2D輸出圖像 //渲染效果,Image_3D共提供了種效果:Isometric,Perspectively,Raytrace //參考...\PEAR\Image\3D\Renderer目錄 $image->createRenderer('perspectively'); //圖像驅動,也可以SVG,ASCII等 //參考...\PEAR\Image\3D\Driver目錄 $image->createDriver('gd'); //創建輸出圖片名稱及大小 $image->render(400, 300, 'object.png'); //顯示效果圖 echo '<img src="object.png">'; ?>
效果圖:
4. 3D文字效果
將上例創建3D圓錐體部分代碼替換為:
//創建3D字體 $text = $image->createObject('text','cnblogs'); $text->setColor(new Image_3D_Color(255, 255, 255)); $text->transform($image->createMatrix('scale', array(10, 10, 20))); $text->transform($image->createMatrix('rotation', array(20, 0, 20))); $text->transform($image->createMatrix('move', array(-150, -100, 0)));
效果圖:
源代碼下載:
本文轉自Gnie博客園博客,原文鏈接:http://www.cnblogs.com/gnielee/archive/2009/08/27/1555038.html,如需轉載請自行聯系原作者