国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

java3D中平行光投影的實(shí)現(xiàn)

2019-11-18 15:05:24
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

理論根據(jù):
假設(shè)一個(gè)光的方向是(-1,-1,-1) , 投影到XZ平面

一個(gè)是直線方程,一個(gè)是平面方程,求交
而且平面方程還比較非凡,經(jīng)過(guò)原點(diǎn),法向量是 0 1 0
簡(jiǎn)化后就簡(jiǎn)單了, 假定v是直線的方向

  x - vertex.x       y - vertex.y        z-vertex.z
----------------  = --------------- = --------------         直線方程
     v.x               v.y                 v.z

平面方程 y = 0

帶入就得到了
x = vertex.x + v.x / v.y * (-vertex.y)
z = vertex.z + v.x / v.z * (-vertex.z)

源程序:
import java.applet.Applet;
import java.awt.BorderLayout;
import java.awt.GraphicsConfiguration;
import java.awt.Label;
import com.sun.j3d.utils.applet.MainFrame;
import com.sun.j3d.utils.universe.*;
import com.sun.j3d.utils.geometry.*;
import javax.media.j3d.*;
import javax.vecmath.*;
public class SimpleShadow extends Applet{
 //三角平面類
 public class Triplane extends Shape3D{
  TriPlane(Point3f A,Point3f B,Point3f C){
   this.setGeometry(this.createGeometry3(A,B,C));
   this.setAppearance(this.createAppearance());
  }
  //建立三角平面
  
  Geometry createGeometry3(Point3f A,Point3f B,Point3f C){
   TriangleArray plane=new TriangleArray(3,GeometryArray.COORDINATESGeometryArray.NORMALS);
   //設(shè)置平面3個(gè)頂點(diǎn)的坐標(biāo)
   plane.setCoordinate(0,A);
   plane.setCoordinate(1,B);
   plane.setCoordinate(2,C);
   
   //計(jì)算平面法向量
   Vector3f a=new Vector3f(A.x-B.x,A.y-B.y,A.z-B.z);
   Vector3f b=new Vector3f(C.x-B.x,C.y-B.y,C.z-B.z);
   Vector3f n=new Vector3f();
   n.cross(b,a);
   //法向量單位化
   n.normalize();
   //設(shè)置平面3個(gè)頂點(diǎn)的法向量
   plane.setNormal(0,n);
   plane.setNormal(1,n);
      plane.setNormal(2,n);
   return plane;
  }
  
  //創(chuàng)建Material不為空的外觀
  
  Appearance createAppearance(){
   Appearance appear=new Appearance();
   Material material=new Material();
   appear.setMaterial(material);
   return appear;
  }
  
 }
 
 
 //四邊平面類
 public class QuadPlane extends Shape3D{
  
  QuadPlane(Point3f A,Point3f B,Point3f C,Point3f D){
   this.setGeometry(this.createGeometry4(A,B,C,D));
   this.setAppearance(this.createAppearance());
  }
  
  //創(chuàng)建四邊性平面
  Geometry createGeometry4(Point3f A,Point3f B,Point3f C,Point3f D){
   QuadArray plane=new QuadArray(4,GeometryArray.COORDINATESGeometryArray.NORMALS);
   //設(shè)置平面3個(gè)頂點(diǎn)的坐標(biāo)
   plane.setCoordinate(0,A);
   plane.setCoordinate(1,B);
   plane.setCoordinate(2,C);
   plane.setCoordinate(3,D);
   //計(jì)算平面法向量
   Vector3f a=new Vector3f(A.x-B.x,A.y-B.y,A.z-B.z);
   Vector3f b=new Vector3f(C.x-B.x,C.y-B.y,C.z-B.z);
   Vector3f n=new Vector3f();
   n.cross(b,a);
   //法向量單位化
   n.normalize();
   //設(shè)置平面4個(gè)頂點(diǎn)的法向量
   plane.setNormal(0,n);
   plane.setNormal(1,n);
   plane.setNormal(2,n);
   plane.setNormal(3,n);
   return plane;
  }
  
 



發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 梨树县| 南丰县| 舒城县| 桦川县| 普陀区| 张家港市| 永吉县| 吉木乃县| 甘孜县| 巩义市| 饶平县| 长宁区| 双柏县| 调兵山市| 临沧市| 朝阳市| 新干县| 萨迦县| 鄂温| 陵川县| 通榆县| 阿尔山市| 上饶县| 贺兰县| 华蓥市| 海丰县| 中卫市| 辉县市| 乡宁县| 宝坻区| 武定县| 南皮县| 丹寨县| 依兰县| 城口县| 廊坊市| 扶风县| 永靖县| 玉龙| 固原市| 泰安市|