Java 3D入门之基本图形功能 附源码

目录
  • 坐标系
  • 基本体组合的显示实例
  • 三角面图形
  • 三角扇图形
  • 四边面图形

坐标系

  • 1、原点O在显示器的中间。
  • 2、Z轴是指向屏幕之外的,也就是观察者。
  • 3、由于观察者眼睛,即观察方向是指向Z轴的反方向,所以当定义好图形之后,光源的方向一定不能是指向Z轴的正方向,否则无法观察到图形。(根据光的反射)

基本体组合的显示实例

import java.applet.Applet;
import java.awt.BorderLayout;
import java.awt.GraphicsConfiguration;

import javax.media.j3d.*;
import javax.vecmath.Color3f;
import javax.vecmath.Point3d;
import javax.vecmath.Vector3f;

import com.sun.j3d.utils.applet.MainFrame;
import com.sun.j3d.utils.behaviors.mouse.MouseRotate;
import com.sun.j3d.utils.behaviors.mouse.MouseTranslate;
import com.sun.j3d.utils.behaviors.mouse.MouseZoom;
import com.sun.j3d.utils.geometry.Box;
import com.sun.j3d.utils.geometry.Sphere;
import com.sun.j3d.utils.universe.SimpleUniverse;

public class towprimitivedisplay extends Applet {
	public BranchGroup createBranchGroup()
	    {
		//定义BranchGroup
		BranchGroup BranchGroupRoot = new BranchGroup ();

		//创建球心在坐标系原点球形范围
		BoundingSphere bounds = new BoundingSphere(new Point3d( 0.0,0.0,0.0),100.0);

		//定义背景颜色
		Color3f bgColor=new Color3f(.0f,.0f,.0f);
		Background bg=new Background(bgColor);
		bg.setApplicationBounds(bounds);
		BranchGroupRoot.addChild(bg);

		//定义平行光、颜色、照射方向与作用范围
		Color3f directionColor=new Color3f(1.f,1.f,1.f);
		Vector3f vec=new Vector3f(1.0f,-1.0f,-1.0f);
		DirectionalLight directionalLight= new DirectionalLight(directionColor,vec);
		directionalLight.setInfluencingBounds(bounds);
		BranchGroupRoot.addChild(directionalLight);

		//定义总的TransformGroup:transformgroup
		TransformGroup transformgroup=new TransformGroup();

		//设置对该TransformGroup的读写能力
		transformgroup.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
		transformgroup.setCapability(TransformGroup.ALLOW_TRANSFORM_READ);

		//将该TransformGroup加入到BranchGroupRoot中
		BranchGroupRoot.addChild(transformgroup);

		//定义鼠标对场景的旋转、平移与放大功能
		MouseRotate mouserotate=new MouseRotate();
		mouserotate.setTransformGroup(transformgroup);
		BranchGroupRoot.addChild(mouserotate);
		mouserotate.setSchedulingBounds(bounds);

		MouseZoom mousezoom=new MouseZoom();
		mousezoom.setSchedulingBounds(bounds);
		BranchGroupRoot.addChild(mousezoom);
		mousezoom.setSchedulingBounds(bounds);

		MouseTranslate mousetranslate=new MouseTranslate();
		mousetranslate.setTransformGroup(transformgroup);
		BranchGroupRoot.addChild(mousetranslate);
		mousetranslate.setSchedulingBounds(bounds);

		//定义两个三维型体的外观
		Appearance app1=new Appearance();
		Material material1=new Material();
		material1.setDiffuseColor(new Color3f(1.0f,.0f,0.0f));
		app1.setMaterial(material1);

		Appearance app2=new Appearance();
		Material material2=new Material();
		material2.setDiffuseColor(new Color3f(0.0f,1.0f,0.0f));
		app2.setMaterial(material2);

		//定义一个球体于一个长方体的大小、外观属性与坐标变换,并定义相应的TransformGroup:ta1、ta2
		TransformGroup tg1=new TransformGroup();
		tg1.addChild(new Sphere(0.3f,app1));
		Transform3D t=new Transform3D();
		t.setTranslation(new Vector3f(0.f,-0.425f,0.f));
		TransformGroup tg2=new TransformGroup(t);
		tg2.addChild(new Box(0.5f,0.05f,0.5f,app2));

		//将定义好的两个TransformGroup(tg1、tg2)加入到总的transformgroup
		transformgroup.addChild(tg1);
		transformgroup.addChild(tg2);

		//对BranchGroupRoot预编译
		BranchGroupRoot.compile();

		//通过方法名返回BranchGroupRoot
		return BranchGroupRoot;
		}
	    public towprimitivedisplay()
	   {
	    //设置显示界面的相关参数
	    setLayout(new BorderLayout());
	    //创建投影平面Canvas3D
	    GraphicsConfiguration gc=SimpleUniverse.getPreferredConfiguration();
	    Canvas3D c=new Canvas3D(gc);
	    //将投影平面上的图像显示在显示平面的中间
	    add("Center",c);
	    //设置SimpleUniverse,由系统选择视点在z轴的正向,观察方向沿z轴反向
	    BranchGroup BranchGroupScene=createBranchGroup();
	    SimpleUniverse u=new SimpleUniverse(c);
	    u.getViewingPlatform().setNominalViewingTransform();
	    //将BranchGroup:BranchGroupScene加入到SimpleUniverse:u中
	    u.addBranchGraph(BranchGroupScene);
	   }

	    public static void main(String[] args)
	    {//通过MainFrame显示图像

	    	new MainFrame(new towprimitivedisplay(),300,300);

	    }
}

由于光源方向是:
Vector3f vec=new Vector3f(-1.f,-1.f,-1.0f); 即指向第七象限。所以结果是:

如果改变光源方向:
Vector3f vec=new Vector3f(0.0f,0.0f,-1.0f);光源指向Z轴反方向

Vector3f vec=new Vector3f(-1.0f,0.0f,0.0f);光源指向X轴反方向

三角面图形

以一维数组给出顶点的坐标值,从前向后一次以3个顶点形成一个三角形,并且上一个三角形与下一个三角形之间没有公共顶点。

import java.awt.BorderLayout;
import java.awt.GraphicsConfiguration;

import javax.media.j3d.Appearance;
import javax.media.j3d.Background;
import javax.media.j3d.BoundingSphere;
import javax.media.j3d.BranchGroup;
import javax.media.j3d.Canvas3D;
import javax.media.j3d.DirectionalLight;
import javax.media.j3d.PolygonAttributes;
import javax.media.j3d.Shape3D;

import javax.media.j3d.TransformGroup;
import javax.media.j3d.TriangleArray;
import javax.vecmath.Color3f;
import javax.vecmath.Point3d;
import javax.vecmath.Vector3f;

import com.sun.j3d.utils.applet.MainFrame;
import com.sun.j3d.utils.behaviors.mouse.MouseRotate;
import com.sun.j3d.utils.behaviors.mouse.MouseTranslate;
import com.sun.j3d.utils.behaviors.mouse.MouseZoom;

import com.sun.j3d.utils.universe.SimpleUniverse;

import java.applet.Applet;

public class DisplayTriangles extends Applet {
	public BranchGroup createBranchGroup() {
		BranchGroup BranchGroupRoot = new BranchGroup();
		BoundingSphere bounds = new BoundingSphere(new Point3d(0.0, 0.0, 0.0), 100.0);
		Color3f bgColor = new Color3f(1.0f, 1.0f, 1.0f);
		Background bg = new Background(bgColor);
		bg.setApplicationBounds(bounds);
		BranchGroupRoot.addChild(bg);

		Color3f directionalColor = new Color3f(1.f, 0.f, 0.f);
		Vector3f vec = new Vector3f(0.f, 0.f, -1.0f);
		DirectionalLight directionalLight = new DirectionalLight(directionalColor, vec);
		directionalLight.setInfluencingBounds(bounds);
		BranchGroupRoot.addChild(directionalLight);

		TransformGroup transformgroup = new TransformGroup();
		transformgroup.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
		transformgroup.setCapability(TransformGroup.ALLOW_TRANSFORM_READ);
		BranchGroupRoot.addChild(transformgroup);

		MouseRotate mouserotate = new MouseRotate();
		mouserotate.setTransformGroup(transformgroup);
		BranchGroupRoot.addChild(mouserotate);
		mouserotate.setSchedulingBounds(bounds);
		MouseZoom mousezoom = new MouseZoom();
		mousezoom.setTransformGroup(transformgroup);
		BranchGroupRoot.addChild(mousezoom);
		mousezoom.setSchedulingBounds(bounds);
		MouseTranslate mousetranslate = new MouseTranslate();
		mousetranslate.setTransformGroup(transformgroup);
		BranchGroupRoot.addChild(mousetranslate);
		mousetranslate.setSchedulingBounds(bounds);

		transformgroup.addChild(new TriangleArrays());
		BranchGroupRoot.compile();
		return BranchGroupRoot;
	}

	public DisplayTriangles() {
		setLayout(new BorderLayout());
		GraphicsConfiguration gc = SimpleUniverse.getPreferredConfiguration();
		Canvas3D c = new Canvas3D(gc);
		add("Center", c);
		BranchGroup BranchGroupScene = createBranchGroup();
		SimpleUniverse u = new SimpleUniverse(c);
		u.getViewingPlatform().setNominalViewingTransform();
		u.addBranchGraph(BranchGroupScene);
	}

	public static void main(String[] args) {
		new MainFrame(new DisplayTriangles(), 300, 300);
	}
}

//outsideclass
class TriangleArrays extends Shape3D {
	public TriangleArrays() {
		int vCount = 12;
		float vertexes[] = { -0.6f,0.9f,0.0f,  -0.6f,-0.9f,0.2f,
				             -0.4f, 0.9f, -0.2f, -0.2f, -0.9f, 0.2f,
				              0.0f, 0.9f,-0.2f,   0.0f, -0.9f, 0.2f,
				              0.2f, 0.7f, 0.0f,   0.2f, -0.9f, 0.3f,
				              0.5f, 0.8f, -0.3f,   0.6f, -.9f, 0.0f,
				              0.8f, 0.9f, 0.2f,   0.8f, -0.8f, 0.3f };
		float colors[] = { 0.0f,0.5f,1.0f,    0.0f,0.5f,1.0f,
                0.0f,0.8f,.0f,    1.0f,0.0f,0.3f,
                0.0f,1.0f,0.5f,   0.9f,1.0f,0.0f,
                0.5f,0.0f,1.0f,   0.0f,0.5f,1.0f,
                1.0f,0.5f,0.0f,   1.0f,0.0f,0.5f,
                1.0f,0.8f,0.0f,   1.0f,0.5f,0.0f};
		TriangleArray trianglearray = new TriangleArray(vCount, TriangleArray.COORDINATES | TriangleArray.COLOR_3);
		trianglearray.setCoordinates(0, vertexes);
		trianglearray.setColors(0, colors);
		PolygonAttributes polygonattributes = new PolygonAttributes();
		//polygonattributes.setCullFace(PolygonAttributes.CULL_NONE);
//polygonattributes.setCullFace(PolygonAttributes.CULL_FRONT);
polygonattributes.setCullFace(PolygonAttributes.CULL_BACK);
		Appearance app = new Appearance();
		app.setPolygonAttributes(polygonattributes);
		this.setGeometry(trianglearray);
		this.setAppearance(app);
	}
}

三角扇图形

以第一个顶点为公用顶点,依次与其余顶点分别连接形成三角形。其中给定的定点数至少为3个。

class ShapeTriangleFanArray extends Shape3D {
	public ShapeTriangleFanArray() {
		int vertexesCount = 12;
		int stripCount[] = new int[1];
//int stripCount[]=new int[2];
//int stripCount[]=new int[3];
		float vertexes[] = { .0f, 0.9f, 0.0f, -1.f, -0.8f, 0.f,
				-0.8f, -0.6f, -0.2f, -0.6f, -0.9f, 0.2f,
				-0.4f, -0.8f,-0.2f, 0.f, -0.8f, 0.2f,
				0.2f, -0.5f, 0.0f, 0.4f, -0.6f, -0.5f,
				0.6f, -0.8f, -0.3f, 0.8f, -0.9f, -0.2f,
				0.9f, -0.7f, -0.2f, 1.1f, -0.8f, -0.3f
				};
		float colors[] = { 0.0f, 0.5f, 1.0f, 0.0f, 0.5f, 1.0f,
				0.0f, 0.8f, .0f, 1.0f, 0.0f, 0.3f,
				0.0f, 1.0f, 0.5f,0.9f, 1.0f, 0.0f,
				0.5f, 0.0f, 1.0f, 0.0f, 0.5f, 1.0f,
				1.0f, 0.5f, 0.0f, 1.0f, 0.0f, 0.5f,
				1.0f, 0.8f,0.0f, 1.0f, 0.5f, 0.0f };
		stripCount[0] = 12;
//stripCount[1]=4;
//stripCount[2]=4;
		TriangleFanArray triangleFanarray = new TriangleFanArray(vertexesCount,
				TriangleFanArray.COORDINATES | TriangleFanArray.COLOR_3, stripCount);
		triangleFanarray.setCoordinates(0, vertexes);
		triangleFanarray.setColors(0, colors);
		PolygonAttributes polygonattributes = new PolygonAttributes();
		polygonattributes.setCullFace(PolygonAttributes.CULL_NONE);
		Appearance app = new Appearance();
		app.setPolygonAttributes(polygonattributes);
		this.setGeometry(triangleFanarray);
		this.setAppearance(app);
	}
}

int stripCount[];数组表示生成的三角扇个数
eg:总共十二个顶点
new stripCount[1],表示生成一个扇区。所以stripCount[0]=12,这一个扇区有十二个点。

该程序,用顶点颜色插值生成线与面颜色,这种颜色无需光照,也能显示。

四边面图形

以顶点坐标数组中给出的一维顶点数组,从前向后依次以4个顶点形成一个四边形面,并且相邻两个四边形面之间没有公用顶点。给定的总的顶点数必须是4的倍数。

class ShapeQuadArray extends Shape3D
{public ShapeQuadArray()
{int vertexCount=12;
float vertexes[]={ -0.8f,0.9f,0.0f, -0.8f,-0.8f,0.f,
                   -0.6f,-0.8f,0.f, -0.6f,0.9f,0.f,
                   -0.4f,0.9f,0.f,  -0.4f,-0.7f,-0.9f,
                    0.4f,-0.8f,0.f,  0.4f,0.8f,0.0f,
                    0.5f,0.8f,0.f,   0.6f,-0.8f,0.0f,
                    0.8f,-0.7f,0.f,  0.8f,0.8f,0.f};
float colors[]={0.0f,0.5f,1.0f,  0.0f,0.5f,1.0f,
                0.0f,0.8f,.0f,   1.0f,0.0f,0.3f,
                0.0f,1.0f,0.5f,  0.9f,1.0f,0.0f,
                0.5f,0.0f,1.0f,  0.0f,0.5f,1.0f,
                1.0f,0.5f,0.0f,  1.0f,0.0f,0.5f,
                1.0f,0.8f,0.0f,  1.0f,0.5f,0.0f };
QuadArray quadarray=new QuadArray(vertexCount,
QuadArray.COORDINATES|QuadArray.COLOR_3);
quadarray.setCoordinates(0,vertexes);
quadarray.setColors(0,colors);
PolygonAttributes polygonattributes=new PolygonAttributes();
polygonattributes.setCullFace(PolygonAttributes.CULL_NONE);
//polygonattributes.setCullFace(PolygonAttributes.CULL_BACK);
//polygonattributes.setCullFace(PolygonAttributes.CULL_FRONT);
Appearance app=new Appearance();
app.setPolygonAttributes(polygonattributes);
this.setGeometry(quadarray);
this.setAppearance(app);
}}

到此这篇关于Java 3D入门之基本图形功能 附源码的文章就介绍到这了,更多相关Java 3D内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • javafx实现图片3D翻转效果方法实例

    实现步骤: 1.定义FlipView对象.包含以下属性: 复制代码 代码如下: //正面视图 public Node frontNode; //反面视图 public Node backNode; //是否翻转 boolean flipped = false; //翻转角度 DoubleProperty time = new SimpleDoubleProperty(Math.PI / 2); //正面翻转特效 PerspectiveTransform frontEffect = new Per

  • Java 3D入门之基本图形功能 附源码

    目录 坐标系 基本体组合的显示实例 三角面图形 三角扇图形 四边面图形 坐标系 1.原点O在显示器的中间. 2.Z轴是指向屏幕之外的,也就是观察者. 3.由于观察者眼睛,即观察方向是指向Z轴的反方向,所以当定义好图形之后,光源的方向一定不能是指向Z轴的正方向,否则无法观察到图形.(根据光的反射) 基本体组合的显示实例 import java.applet.Applet; import java.awt.BorderLayout; import java.awt.GraphicsConfigura

  • C++ Opengl图形颜色功能附源码下载

    项目开发环境: 开发语言:C++和IDE:VS2017,操作系统Windows版本windows SDK8.1,三方库:OpenGL. 项目功能: 创建一个有颜色的图形. 项目源码如下: /*********************包含链接的库文件*******************************************************************************************/ #pragma comment( lib, "opengl32.l

  • C++ Opengl旋转功能附源码下载

    项目开发环境: 开发语言:C++和IDE:VS2017,操作系统Windows版本windows SDK8.1,三方库:OpenGL. 项目功能: 是图形旋转起来. 项目源码如下: /*********************包含链接的库文件*******************************************************************************************/ #pragma comment( lib, "opengl32.lib&

  • Springboot+Thymeleaf+Jpa实现登录功能(附源码)

    前言 最近有学习到关于Springboot+Thymeleaf+Jpa的综合运用知识,因此想写一个简单的登录界面来尝试一下,以下将展示具体流程 具体实现 首先要创建一个springboot项目 添加以下依赖项 pom.xml代码 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi=&

  • jQuery+Ajax+PHP实现“喜欢”评级功能附源码下载

    本文章来给大家介绍一个jQuery+Ajax+PHP实现"喜欢"评级功能代码,用户点击页面中自己喜欢的图片上的红心按钮时,前端页面向后台发送一个ajax请求,后台PHP程序接收请求后,查询IP库中是否已经有该用户的点击记录,如果没有,则将对应的数值+1,同时将该用户IP信息写入IP库,反之则告诉用户已经"喜欢过了".  源码下载地址:http://xiazai.jb51.net/201509/yuanma/loveit(jb51.net).rar 实现过程 本文基于

  • jQuery实现产品对比功能附源码下载

    产品对比相信大家并不陌生,为了方便用户对类似产品的相关信息进行有效直观的对比,一些电商网站产品或评测网站会为用户提供产品对比的功能,用户只需勾选多个需要对比的产品,就可以进行比对.本文将使用jQuery来给大家讲解如何实现产品对比功能. 查看演示     下载源码 HTML HTML结构我们分三部分,第一是产品列表部分,展示所有可以对比的产品.我们以某手机网站为例,简单的结构,只需展示产品图片和名称,以及一个添加按钮.注意我们把手机的相关参数信息都放在属性data-*里,等会后面展示对比信息的时

  • python绕过图片滑动验证码实现爬取PTA所有题目功能 附源码

    最近学了python爬虫,本着学以致用的态度去应用在生活中.突然发现算法的考试要来了,范围就是PTA刷过的题.让我一个个复制粘贴?不可能,必须爬它! 先开页面,人傻了,PTA的题目是异步加载的,爬了个寂寞(空数据).AJAX我又不熟,突然想到了selenium. selenium可以模拟人的操作让浏览器自动执行动作,具体的自己去了解,不多说了.干货来了: 登录界面有个图片的滑动验证码 破解它的最好方式就是用opencv,opencv巨强,自己了解. 思路开始: 1.将背景图片和可滑动的图片下载

  • 微信小程序实现天气预报功能(附源码)

    前言 最近在学小程序开发,刚好学到天气预报功能的制作,于是给大家分享下. 效果图 天气API获取 这里我用的是和风天气的API,打开官网注册或者登陆你的账号 进入控制台,新建应用 这是刚刚我们创建好的应用,点击添加KEY 选择WebAPI 这注册好我们的API了 微信小程序后台域名配置 登陆小程序后台,分别点击开发和开发设置 点击修改,将我们API的域名添加到request合法域名里面https://free-api.heweather.net 页面代码 .wxml <view class=&quo

  • 使用Python实现简单的人脸识别功能(附源码)

    目录 前言 一.首先 二.接下来 1.对照人脸获取 2. 通过算法建立对照模型 3.识别 前言 今天,我们用Python实现简单的人脸识别技术! Python里,简单的人脸识别有很多种方法可以实现,依赖于python胶水语言的特性,我们通过调用包可以快速准确的达成这一目的.这里介绍的是准确性比较高的一种. 一.首先 梳理一下实现人脸识别需要进行的步骤: 流程大致如此,在此之前,要先让人脸被准确的找出来,也就是能准确区分人脸的分类器,在这里我们可以用已经训练好的分类器,网上种类较全,分类准确度也比

  • SpringBoot从0到1整合银联无跳转支付功能附源码

    前言 提示:这里可以添加本文要记录的大概内容: 例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容. 提示:以下是本篇文章正文内容,下面案例可供参考 一.官网 https://open.unionpay.com/tjweb/user/mchTest/param 个人登录后的相关参数查看 其实在接入支付之前建议大家了解下 对称加密,分对称加密RSA之类,摘要算法,https,证书等这些知识点,因为此代码后面的验签,判断都是基于此的

随机推荐