`
luliangok
  • 浏览: 776070 次
文章分类
社区版块
存档分类
最新评论

Doja平台上的3D机器人程序

 
阅读更多
Doja平台上的3D机器人程序
这个机器人程序实现了常见的3D基础操作:移动,旋转,光照,纹理,动画等等。说明:这个程序参考了j2medev网上的一篇文章,原文链接:精通Micro3Dv3基础技术
程序中所使用的资源文件也来自该文章附带的文件中。我只是将其移植到doja平台罢了,在此过程中学习3D知识。程序代码及效果图:下载
飘飘白云
2006-01-26
import com.nttdocomo.ui.*;
import com.nttdocomo.opt.ui.j3d.*;
import javax.microedition.io.*;
//
/**
* @author ppby 2006-01-26
* Doja 3D examples.
*/
public class Robot_3D extends IApplication {
private Canvas3D canv;
public void start() {
try {
canv = new Canvas3D();
Display.setCurrent(canv);
Thread thread = new Thread(canv);
thread.start();
} catch (IllegalThreadStateException itse) {
itse.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
}
/**
* Canvas class
*/
class Canvas3D extends Canvas implements Runnable {
Graphics g = null;
private String[] msg = {
"Move:up,down,left,right key.",
"Light :KEY_7,KEY_9.",
"Rotate:KEY_1,KEY_3.",
"Zoom:KEY_2,KEY_8.",
"Actions :KEY_5.",
};
// 3D affine transformation matrix
private AffineTrans viewT = new AffineTrans();
private AffineTrans viewBGT = new AffineTrans();
private AffineTrans affineT = new AffineTrans();
private AffineTrans tempTrans = new AffineTrans();
private int rotY; // Variable for rotation
private int nScale; // Variable for zoom/scale
private int nTransX,nTransY;// Variable for translation
private int nAmLight = 4096 * 7/8 ;//ambient light intensity
private Figure figureBG; //background figure
private Figure figure; //robot figure
private Texture texture; // texture for figures.
private ActionTable[] action = new ActionTable[2];
private int frame; //frame of action
private int actNo; //No. of action
public Canvas3D() {
//init data
g = this.getGraphics();
actNo = 0;
frame = 0;
try {
// Set a camera:(position,look at,up direction
//background view port
viewBGT.lookAt(
new Vector3D(0, 0, 1800),
new Vector3D(0, 0, 200),
new Vector3D(0, 4096, 0));
//robot view port
viewT.lookAt(
new Vector3D(0, 0, 800),
new Vector3D(0, 0, 200),
new Vector3D(0, 4096, 0));
//Init resource
figureBG = new Figure(Connector.openDataInputStream("resource:///test_model_haikei.mbac"));
figure= new Figure(Connector.openDataInputStream("resource:///test_model_robo.mbac"));
texture = new Texture(Connector.openDataInputStream("resource:///tex_001.bmp"), false);
action[0] = new ActionTable(Connector.openInputStream("resource:///action_01.mtra"));
action[1] = new ActionTable(Connector.openInputStream("resource:///action_02.mtra"));
figure.setTexture(texture);
figureBG.setTexture(texture);
} catch (Exception e) {
System.out.println("Init data failed");
e.printStackTrace();
}
}
public void run() {
while (true) {
update(); //update
render(); //draw
try {
Thread.sleep(100); // wait 100ms
} catch (InterruptedException ie) {
System.out.println("Run error~~");
}
}
}
public void update()
{
affineT.setIdentity();
//tranlate
tempTrans.setIdentity();
tempTrans.m03 += nTransX;
tempTrans.m13 += nTransY;
affineT.mul(tempTrans);
//rotate y axis
tempTrans.setIdentity();
tempTrans.setRotateY(rotY);
affineT.mul(tempTrans);
//zoom (scale)
tempTrans.setIdentity();
tempTrans.setElement(0, 0, tempTrans.m00 + nScale);
tempTrans.setElement(1, 1, tempTrans.m11 + nScale);
affineT.mul(tempTrans);
//action
frame += action[actNo].getMaxFrame(0)/10;
if( frame >= action[actNo].getMaxFrame(0) ){
frame = 0;
actNo = 0;
}
figure.setPosture(action[actNo], 0, frame);
}
public void render()
{
try {
g.lock();
// Background Clear
g.setColor(Graphics.getColorOfRGB(0, 0, 0));
g.fillRect(0, 0, getWidth(), getHeight());
Graphics3D g3d = (Graphics3D) g;
g3d.setClipRect3D(0, 0, getWidth(),getHeight());
g3d.setScreenCenter(getWidth()>>1, getHeight()>>1);
g3d.setPerspective(200, 10000, 4096*50/360);
//set light
g3d.setAmbientLight(nAmLight);
g3d.setDirectionLight(new Vector3D(1,1,0),4096/2);
g3d.enableLight(true);
//background figure
g3d.setViewTrans(viewBGT);// Set view coordinate matrix
g3d.renderFigure(figureBG);
g3d.drawFigure(figureBG);
//robot figure
affineT.mul(viewT,affineT);
g3d.setViewTrans(affineT); // //set viewport
g3d.renderFigure(figure);
g3d.drawFigure(figure);
g3d.flush();
g.setColor(Graphics.getColorOfRGB(0, 255, 0xff));
for(int i = 0;i < msg.length; i++){
g.drawString(msg[i], 5, (i + 1)*( 2 + Font.getDefaultFont().getHeight()));
}
g.unlock(true);
} catch (Exception e) {
System.out.println("Paint() err");
e.printStackTrace();
}
}
/**
* Key event process.
*/
public void processEvent(int type, int param) {
try {
if (type == Display.KEY_PRESSED_EVENT) {
switch (param) {
//translate
case Display.KEY_UP://move up
nTransY += 15;
break;
case Display.KEY_DOWN://move down
nTransY -= 15;
break;
case Display.KEY_LEFT://move left
nTransX -= 15;
break;
case Display.KEY_RIGHT://move right
nTransX += 15;
break;
//rotate
case Display.KEY_1://rotate left
rotY -= 128;
rotY %= 4096;
break;
case Display.KEY_3://rotate right
rotY += 128;
rotY %= 4096;
break;
//zoom/scale
case Display.KEY_8://zoom in
nScale -= 128;
break;
case Display.KEY_2://zoom out
nScale += 128;
break;
//change action
case Display.KEY_5:
actNo = 1;
frame = 0;
break;
//change light intensity
case Display.KEY_7://weak light
nAmLight -= 512;
nAmLight %= 4096;
nAmLight = (nAmLight<0? 1:nAmLight);
break;
case Display.KEY_9://strong light
nAmLight += 512;
nAmLight = (nAmLight>=4096 ? 4095:nAmLight);
nAmLight %= 4096;
break;
}
}
} catch (Exception e) {
System.out.println("Set attribute value err");
e.printStackTrace();
}
}
public void paint(Graphics _g) {
}
}
分享到:
评论

相关推荐

    Doja SDK 5.1 en

    DoJa是NTT DoCoMo用于其i-mode服务的Java应用概要,DoJa运行在J2ME CLDC API上,该API是Java Community Process(JCP)定义的,DoJa扩展库是由NTT DoCoMo制定的,用于通讯和其他输入输出处理、用户界面(GUI)和其他...

    InputStreamReader_test.rar_doja_doja中文_简体 繁体

    doja中文简体中文与繁体中文转换例子(doja2.5开发环境)

    DoJa-1942:使用 iAppli SDK 1.5 从 J2ME 1942 移植到 DoJa(2005 年 5 月)

    总结 我将我的 J2ME 1942 克隆移植到 i-mode (DoJa) 平台 运行 JAR 的要求 Java 2 运行时环境 DoJa 1.5 模拟器版1.07 可以从 DoJa 开发者网络下载: 如何玩演示 可分发文件位于“dist”文件夹中 箭头(或 8/2、4/6...

    DoJa Trivia Quiz-开源

    适用于支持 DoJa 2.5 的手机的琐事问答游戏。

    Doja Cat New Tab Wallpapers New Tab Theme-crx插件

    在每个新标签页上都包含yoru最喜欢的说唱歌手Doja Cat的高清图像!对于说唱和嘻哈迷! 请给我们评分!如果您觉得我们不值得5星级,请给我们发送电子邮件或先致电给我们!我们希望收到你的来信! support@...

    JammedUp-开源

    JammedUp(JAM和JAD Update的缩写)是一个自动化的MIDP和DoJa描述符文件同步器。 MIDlet分为JAR可执行文件和描述符文件,这是下载前对JAR文件内容的简短但准确的描述。

    java XML sax parser (2kb)-开源

    这是一个为所有 Java 设备制作的小型 SAX 解析器。 它可以从非常小的设备(从 Midp 到 DoJa 的典型 java 电话)到企业服务器使用。 现在,它仅支持 SAX 解析器模型。 使用非常简单(请参阅 .java 示例)。 提示是

Global site tag (gtag.js) - Google Analytics