手机上J2ME的3D编程-简单创建3D立方体(1)

编程|创建

参考文档:JSR-184

工具:Eclipse3.0+Eclipseme

API:Mobile 3D Graphics API

模拟器:Sony Ericsson

分析:

在现实生活中,我们所看到的是一个3维系统。透过双眼,可以看到的是一个丰富多彩的世界。我们所用的照相机,能够拍出很多漂亮的图片。拍摄每张图片时,可以根据拍摄距离的远近可以调整所拍摄画面上的内容。

在虚拟的世界里,可以模拟真实世界。欲将虚拟世界展示出来,就要利用一个虚拟的照相机,将虚拟的世界拍摄出来。

在JSR-184中,虚拟的世界是由World类构造的。虚拟的照相机是Camera类。通过Camera的位置或视角的改面,将虚拟世界显示到手机屏幕上。Camera默认是朝向Z轴的负方向。在虚拟世界中,各个物体都是由Mesh类创建的。不同的Mesh属性对应不同的物体。

构造物体时,先要构造物体的骨架(即形状),然后用一种材料蒙到骨架上。物体的形状,是由一组点和每个点的法向量决定的。材料则是图片。

下面按照与上面相反的顺序再一个虚拟的世界中构建一个立方体。步骤如下:

1 构造立方体

构造一个立方体需要给出立方体的各个顶点,然后规定各个顶点的法向量,最后将图片帖到由顶点和各点法向量构成的架子上。

各个顶点的给出,是和法向量配合的。由于立方体是由6个矩形组成的,所以就要确定这6个矩形。因为由一个点和一个法向量就能够确定一个面,那么4个顶点和4个法向量就确定了4个面。如果这4个面重叠,4个顶点就构成了一个矩形的区域。用这个方法确定6个矩形,再用这6个举行组成一个立方体。

将图片帖到立方体是,就是将立方体上的顶点和图片上的点进行对应。两者可以用不同的单位。

下面构建一个立方体

给出立方体的顶点们:

short x = 20;

short y = 20;

short z = 20;

short fx = (short) -x;

short fy = (short) -y;

short fz = (short) -z;

short[] vert = {x,y,z, fx,y,z, x,fy,z, fx,fy,z, //D

fx,y,fz, x,y,fz, fx,fy,fz, x,fy,fz, //C

fx,y,z, fx,y,fz, fx,fy,z, fx,fy,fz, //B

x,y,fz, x,y,z, x,fy,fz, x,fy,z, //F

x,y,fz, fx,y,fz, x,y,z, fx,y,z, //A

x,fy,z, fx,fy,z, x,fy,fz, fx,fy,fz}; //E

VertexArray vertArray = new VertexArray(vert.length/3, 3, 2);

vertArray.set(0, vert.length/3, vert);

给出立方体顶点们的法向量:

byte[] norm = { 0,0,127, 0,0,127, 0,0,127, 0,0,127,

0,0,-127, 0,0,-127, 0,0,-127, 0,0,-127,

-127,0,0, -127,0,0, -127,0,0, -127,0,0,

127,0,0, 127,0,0, 127,0,0, 127,0,0,

0,127,0, 0,127,0, 0,127,0, 0,127,0,

0,-127,0, 0,-127,0, 0,-127,0, 0,-127,0};

VertexArray normArray = new VertexArray(norm.length / 3, 3, 1);

normArray.set(0, norm.length / 3, norm);

给出顶点们对应图片上的点(vert和tex数组是一一对应的):

short[] tex = { 1, 0, 0, 0, 1, 1, 0, 1,

1, 0, 0, 0, 1, 1, 0, 1,

1, 0, 0, 0, 1, 1, 0, 1,

1, 0, 0, 0, 1, 1, 0, 1,

1, 0, 0, 0, 1, 1, 0, 1,

1, 0, 0, 0, 1, 1, 0, 1 };

VertexArray texArray = new VertexArray(tex.length / 2, 2, 2);

texArray.set(0, tex.length / 2, tex);

根据上面给出的数组,组成立方体:

// create the VertexBuffer for our object

VertexBuffer vb = boxVB = new VertexBuffer();

vb.setPositions(vertArray, 1.0f, null);

vb.setNormals(normArray);

vb.setTexCoords(0, texArray, 1.0f, null);

2 将立方体实例化

// the length of each triangle strip

int[] stripLen = { 4, 4, 4, 4, 4, 4 };

// create the index buffer for our object (this tells how to

// create triangle strips from the contents of the vertex buffer).

TriangleStripArray tsa = new TriangleStripArray(0, stripLen);

//创建多边形模式。

PolygonMode pm = new PolygonMode();

pm.setShading(PolygonMode.SHADE_SMOOTH);

pm.setCulling(PolygonMode.CULL_NONE);

//生成外貌。

Appearance app = new Appearance();

app.setPolygonMode(pm);

Image texImg= null;

try{

texImg = Image.createImage(this.imageUrl);

}catch(Exception e){

String strErr="Load Image (path=";

strErr += this.imageUrl;

strErr += ") Fail!";

System.err.println(strErr);

}

Texture2D texture=null;

try{

// create texture from loaded image.

texture = new Texture2D(new Image2D(Image2D.RGB, texImg));

}catch(Exception e){

e.printStackTrace();

String strErr = "Failed to create texture Use Format --- Image2D.RGB";

System.out.println(strErr);

}

try{

// repeat texture on surface

texture.setWrapping(Texture2D.WRAP_REPEAT, Texture2D.WRAP_REPEAT);

}catch(Exception e){

e.printStackTrace();

System.out.println("Failed to create texture3");

}

try{

// Blend mode to use.

texture.setBlending(Texture2D.FUNC_DECAL);

}catch(Exception e){

System.out.println("Failed to create texture4");

}

try{

// Use nearest for performance, linear for quality

texture.setFiltering(Texture2D.FILTER_NEAREST,Texture2D.FILTER_NEAREST);

}catch(Exception e){

System.out.println("Failed to create texture5");

}

try{

app.setTexture(0, texture);

}catch(Exception e){

System.out.println("Failed to create texture6");

}

//创建网格。

mesh = new Mesh(vb, tsa, app);

mesh.setAppearance(0, app);

3 创建World

//create a camera

camera = new Camera();

camera.setPerspective(60.0f, // field of view

(float) getWidth() / (float) getHeight(), // aspectRatio

1.0f, // near clipping plane

1000.0f); // far clipping plane

camera.setTranslation(0,0, 50);

world = new World();

world.addChild(camera);

world.addChild(mesh);

world.setActiveCamera(camera);

4 绘制World

//private Graphics3D g3d = null;

protected void paint(Graphics g) {

// TODO Auto-generated method stub

Draw(g);

}

private void Draw(Graphics g){

try{

g3d.bindTarget(g);

g3d.render(world);

}catch(Exception e){

}finally{

g3d.releaseTarget();

}

}

5 旋转立方体

mesh.postRotate(1.0f, 1.0f, 0f, 0f);

意识是以向量为(1,0,0)的方向(就是x轴)为轴将立方体旋转1度。

至此,就是建造一个虚拟的世界,并放置一个立方体的步骤。上面的代码是从一个完整的程序中截取的,有的地方可能不方便理解。后面将附上完整的代码。

时间: 2024-07-30 10:12:50

手机上J2ME的3D编程-简单创建3D立方体(1)的相关文章

J2ME 3D编程——第一个3D程序

编程|程序 J2ME 3D编程--第一个3D程序(附源代码) 更多文章请访问:http://blog.csdn.net/mailbomb 参考WTK2.2提供的demo,完成了第一个3D程序,虽然很简单,而且有些问题还不是很清楚,还是把代码共享出来和愿意学习J2ME 3D编程的朋友一起学习. 关于3D编程的资料,可以查阅我的blog. 关于代码的编译和运行说明如下: 1. 以下代码在J2ME WTK2.2下面编译通过. 2. 代码分为两个文件:First3DCanvas.java和First3D

J2ME 3D编程——第一个3D程序(附源代码)

参考WTK2.2提供的demo,完成了第一个3D程序,虽然很简单,而且有些问题还不是很清楚,还是把代码共享出来和愿意学习J2ME 3D编程的朋友一起学习. 关于3D编程的资料,可以查阅我的blog. 关于代码的编译和运行说明如下: 1.以下代码在J2ME WTK2.2下面编译通过. 2.代码分为两个文件:First3DCanvas.java和First3DMIDlet.java. 3.使用J2ME WTK2.2建立新的工程,主MIDlet类为:first3d. First3DMIDlet 4.将

3D编程:Real-Time 3D Rendering with DirectX and HLSL

介绍 图形编程是视频游戏,电影和科学模拟仿真背后的魔法.你在计算机屏幕上看到的每一个爆炸,颗粒以及眩光都是使用视频卡处理的.此外,你看到的每一个像素点都是通过GPU渲染和图形编程人员软件实现的,因为现代操作系统使用GPU绘制.这是一个广泛的话题,但一直以来只属于少数领域.甚至有经验的软件开发人员,通常认为渲染是一门高深的艺术,充满了复杂的数学工具和深奥的工具.另外,现代图形学的快速发展使得图形编程变成了不断前进的目标,同时建立一个起点变得更加困难. 这就是这本书的目的.通过这本书,你会学习对实时

《Python数据可视化编程实战》——5.2 创建3D柱状图

5.2 创建3D柱状图 Python数据可视化编程实战 虽然matplotlib主要专注于绘图,并且主要是二维的图形,但是它也有一些不同的扩展,能让我们在地理图上绘图,让我们把Excel和3D图表结合起来.在matplotlib的世界里,这些扩展叫做工具包(toolkits).工具包是一些关注在某个话题(如3D绘图)的特定函数的集合. 比较流行的工具包有Basemap.GTK 工具.Excel工具.Natgrid.AxesGrid和mplot3d. 本节将探索关于mplot3d的更多功能.mpl

《Python数据可视化编程实战》—— 第 5 章 创建3D可视化图表

第 5 章 创建3D可视化图表 Python数据可视化编程实战本章将学习以下内容. 创建3D柱状图创建3D直方图在matplotlib中创建动画用OpenGL制作动画

《Python数据可视化编程实战》——第 5 章 创建3D可视化图表 5.1 简介

第 5 章 创建3D可视化图表 本章将学习以下内容. 创建3D柱状图 创建3D直方图 在matplotlib中创建动画 用OpenGL制作动画 5.1 简介 3D可视化有时候是很有效的,有时候也是不可避免的.在这里我们将展示一些例子,这些例子将满足一些最常用的需求. 本章将会介绍并讲解一些3D可视化的话题.

《Python数据可视化编程实战》——5.3 创建3D直方图

5.3 创建3D直方图 像3D柱状图一样,我们可能想创建3D直方图.3D直方图可以用来很容易地识别3个独立变量之间的相关性.可以用它们来从图像中提取信息,其中第三个维度可以是所分析的图像的(x, y)空间通道的强度. 本节将学习如何创建3D直方图. 5.3.1 准备工作 回顾一下,直方图表示的是一些值在特定列(通常叫做"bin")中的发生率.那么,三维直方图表示的是在一个网格中的发生率.网格是矩形的,表示的是在两列中关于两个变量的发生率. 5.3.2 操作步骤 在这个计算过程中,我们将

《OpenGL超级宝典(第5版)》——第1章,第1.4节3D编程的基本原则

1.4 3D编程的基本原则 现在,我们对实时3D的基本概念已经有了相当程度的认识.我们讨论了一些术语以及PC上的一些示例应用程序.那么,如何在自己的计算机上创建这样的图像呢?好吧,这正是本书剩余部分的任务所在.不过,读者还需要知道一些基础知识,这正是我们接下来将要讨论的. 1.4.1 并非工具包 OpenGL基本上是一种底层渲染API(应用程序接口).我们不能告诉它"在什么地方绘制什么"--我们需要自己动手,通过载入三角形,应用必要的变换和正确的纹理.着色器并在必要时应用混合模式来组合

看实例学VFP:编程方式创建类

上两个例子中介绍了使用"类设计器"来交互方式创建类,与交互方式相对应的,也可以用编程方式创建类.不过用这种方式来创建类很麻烦,并且需要极大的耐心去调试,相对来说用得比较少. 算是扩充一下知识面吧,本文对编程方式定义类的语句格式做一个简单的介绍,但是不必深究和浪费太多的时间,毕竟已经有可视化的.强大的"类设计器"可以用了:否则VFP这三个字母中,打头的这个V(Visual)也就失去其意义了.本文末尾给出了编程方式创建类的一个简单示例代码,运行时界面如下图: 运行时单击