import javax.microedition.lcdui.*;
import javax.microedition.midlet.*;
public class AppMain extends MIDlet{
public MyCanvas mc;
public AppMain()
{
mc=new MyCanvas();
}
public void startApp()
{
Display.getDisplay(this).setCurrent(mc);
}
public void pauseApp()
{}
public void destroyApp(boolean f)
{}
import java.io.DataInputStream;
import java.io.InputStream;
import javax.microedition.lcdui.*;
public class MyCanvas extends Canvas implements Runnable{
public Image offScreen;
public Graphics offg;
public int screenWidth;
public int screenHeight;
public static final int GS_LOGO=1;//logo状态
public static final int GS_MainMENU=2; //主菜单状态
public static final int GS_CHAT=3;//对话绘制状态
public static final int GS_GAMING=4;//游戏状态
public static final int GS_GameMENU=5; //游戏中菜单状态
public static final int GS_LoadMap=6; //游戏中菜单状态
public int sleeptime;
public int gameState=GS_LOGO;
public int count=0;
public Image imlogo;
public Image imMainMenu;
public Image immap;
public Image implayer;
public int mappx;
public int mapnowcol;
public int px=16,py=32;
public static final int P_UP=0;
public static final int P_DOWN=1;
public static final int P_LEFT=2;
public static final int P_RIGHT=3;
public static final int P_STOP=-1;
public int playerdir=P_STOP;
public int oldPlayDir=P_DOWN;
public int nowframe=0;
public String chat[]={
"在公园2009年",
"一位来自XXX的年轻人",
"准备寻找xxx",
"他必须完成xxx任务",
"同时",
"XXX可以协助他",
"准备出发了。。。。"
};
public int map01[][];
public int chatIndex=0;
public DataInputStream dis;
public int processLength;//总进度长度
public int nowprocess;
public int maprow,mapcol;
public int playermove[][]=
{
{0,1,2},//up
{6,7,8},//down
{9,10,11},//left
{3,4,5}//right
};
public MyCanvas()
{
screenWidth=this.getWidth();
screenHeight=this.getHeight();
offScreen=Image.createImage(screenWidth, screenHeight);
offg=offScreen.getGraphics();
imlogo=this.loadImage("/sp1.png");
imMainMenu=this.loadImage("/mainMenu.png");
implayer=this.loadImage("/walk.png");
Thread t=new Thread(this);
t.start();
}
//加载地图
public void LoadMap(int level)
{ this.immap=null;
this.immap=this.loadImage("/mapitem0"+level+".png");
//加载地图数组
this.map01=null;
System.gc();
InputStream is=this.getClass().getResourceAsStream("/map0"+level+".dat");
dis=new DataInputStream(is);
try{
int row=dis.readByte();
int col=dis.readByte();
maprow=row;
mapcol=col;
map01=new int[row][col];
this.processLength=row*col;
this.nowprocess=0;
// for(int i=0;i<row;i++)
// { for(int j=0;j<col;j++)
// {int k=dis.readShort();
// map01[i][j]=k;
// System.out.print(" "+k);
// }
// System.out.println();
// }
}catch(Exception t ){t.printStackTrace();}
}
public Image loadImage(String file)
{Image im=null;
try{
im=Image.createImage(file);
}catch(Exception g ){
System.out.println(file+"加载错误");
}
return im;
}
public void paint(Graphics g)
{//贴图
g.drawImage(offScreen, 0, 0, 0);
}
public void drawMap()
{
for(int i=0;i<19;i++)
{
for(int j=mapnowcol;j<mapnowcol+15;j++)
{ int k=map01[i][j]-1;
offg.setClip((j-mapnowcol)*16, i*16, 16, 16);
int movex=k%5*16;
int movey=k/5*16;
offg.drawImage(this.immap, (j-mapnowcol)*16-movex, i*16-movey, 0);
}
}
offg.setClip(0, 0, screenWidth, screenHeight);
}
public void drawPlayer()
{ offg.setClip(px, py, 16, 24);
if(playerdir!=-1)
offg.drawImage(implayer, px-this.playermove[playerdir][nowframe]*16, py, 0);
else
offg.drawImage(implayer, px-this.playermove[oldPlayDir][0]*16, py, 0);
}
public void drawNPC()
{}
public void drawChat()
{
offg.setColor(0x000000);
offg.fillRect(0, 0, screenWidth, screenHeight);
offg.setColor(0xffffff);
if(chatIndex<=6)
offg.drawString(chat[chatIndex],20, 50, 0);
}
public void drawLogo()
{offg.setColor(0xFFFFFF);
offg.fillRect(0, 0, screenWidth, screenHeight);
int lw=imlogo.getWidth();
int lh=imlogo.getHeight();
offg.drawImage(imlogo, (screenWidth-lw)/2, (screenHeight-lh)/2, 0);
}
public void drawLoading()
{offg.setColor(0xFFFFFF);
offg.fillRect(0, 0, screenWidth, screenHeight);
offg.setColor(0xFF0000);
offg.drawString("游戏载入中...",20, 20, 0);
offg.drawRect(20, 80, 200, 40);
int nowlength=(this.nowprocess*100/this.processLength)*2;
offg.fillRect(20, 80, nowlength, 40);
}
public void drawMainMenu(){
offg.setColor(0xFFFFFF);
offg.fillRect(0, 0, screenWidth, screenHeight);
int lw=imMainMenu.getWidth();
int lh=imMainMenu.getHeight();
offg.drawImage(imMainMenu, (screenWidth-lw)/2, (screenHeight-lh)/2, 0);
offg.setColor(0xFF0000);
offg.drawString("按任意键进入游戏",20, 200, 0);
}
public void keyPressed(int n)
{
switch(this.gameState)
{case MyCanvas.GS_MainMENU:
this.gameState=MyCanvas.GS_CHAT;
break;
case MyCanvas.GS_CHAT:
if(this.chatIndex<7){chatIndex++;}
else{
chatIndex=0;
LoadMap(1);
this.gameState=MyCanvas.GS_LoadMap;
}
break;
case MyCanvas.GS_GAMING:
switch(this.getGameAction(n))
{case Canvas.UP:
playerdir=MyCanvas.P_UP;
oldPlayDir=playerdir;
break;
case Canvas.DOWN:
playerdir=MyCanvas.P_DOWN;
oldPlayDir=playerdir;
break;
case Canvas.LEFT:
playerdir=MyCanvas.P_LEFT;
oldPlayDir=playerdir;break;
case Canvas.RIGHT:
playerdir=MyCanvas.P_RIGHT;
oldPlayDir=playerdir;break;
}
}
}
public void keyReleased(int n)
{
if(this.gameState==MyCanvas.GS_GAMING){
playerdir=MyCanvas.P_STOP;
}
}
public void run()
{
while(true)
{//处理游戏逻辑
switch(this.gameState)
{case MyCanvas.GS_LOGO:
count++;
if(count>=10){
this.gameState=MyCanvas.GS_MainMENU;
count=0;
}
break;
case MyCanvas.GS_LoadMap:
try{
this.nowprocess++;
if(nowprocess<this.processLength)
{
int k=dis.readShort();
map01[nowprocess/maprow][nowprocess%maprow]=k;
}else{
this.gameState=MyCanvas.GS_GAMING;
}
}catch(Exception e){
}
break;
case MyCanvas.GS_GAMING:
nowframe=(++nowframe)%3;
switch(playerdir)
{case MyCanvas.P_UP:
py-=8;
break;
case MyCanvas.P_DOWN:
py+=8;
break;
case MyCanvas.P_LEFT:
px-=8;
break;
case MyCanvas.P_RIGHT:
if(this.px<this.screenWidth/2)
{px+=8;
}else{
mapnowcol++;
}
break;
}
}
//处理屏幕绘制
switch(this.gameState)
{
case MyCanvas.GS_LoadMap:
drawLoading();
break;
case MyCanvas.GS_LOGO:
drawLogo();
break;
case MyCanvas.GS_MainMENU:
drawMainMenu();
break;
case MyCanvas.GS_CHAT:
drawChat();//绘制对话
break;
case MyCanvas.GS_GAMING:
drawMap();//绘制场景
drawPlayer();//绘制人物
drawNPC();//绘制NPC
break;
}
//处理FPS
if(this.gameState==MyCanvas.GS_LoadMap)
sleeptime=1;
else
sleeptime=200;
try{Thread.sleep(sleeptime);}catch(Exception e){}
repaint();
serviceRepaints();
}
}
}
分享到:
相关推荐
《J2MERPG 游戏》是一款基于J2ME技术开发的手机角色扮演游戏。作为一款初试身手的作品,它展示了开发者对Java Micro Edition(J2ME)平台的理解与运用,尤其是在游戏开发领域的实践。J2ME是Java平台的一个子集,专为...
这个“J2meRPG游戏框架源码”提供了一个基础结构,帮助开发者快速创建自己的J2ME RPG游戏。通过研究和理解这些源码,我们可以学习到以下几个核心知识点: 1. **图形渲染**:在J2ME平台上,图形通常使用LWUIT...
在这个标题为“j2meRPG手游代码”的项目中,我们可以看到一个基于J2ME开发的角色扮演游戏(RPG)的实现。下面,我们将深入探讨其中的关键组成部分和实现机制。 1. **战斗场景**:战斗场景是RPG游戏的核心部分,通常...
笔者以前是做J2EE的,一个月前由于兴趣所致开始利用业余时间学习J2ME游戏开发。在网上看了一通教程后,便准备动手一边学一边做一个简单的rpg游戏。虽然起点比较高,但感觉游戏难度越大,遇到的问题也就越多。这样在...
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
内容概要:本文提出了一种新的分析框架,用于评估集中式无线电接入网(RAN)的数据处理需求。作者定义了若干性能指标,如计算失效概率、复杂度、增益、多样性和复杂度率之间的权衡。该模型基于块瑞利衰落、距离相关路径损耗和部分功率控制假设下进行仿真验证,证明了集中计算资源的优势。 适用人群:通信工程领域的研究人员、5G技术开发人员和无线网络优化专家。 使用场景及目标:①理解集中式RAN架构对网络性能的影响;②评估集中化数据处理资源在提高吞吐量方面的效益;③量化集中式RAN系统的数据处理复杂度和可靠性。 其他说明:文章通过对多种场景和参数设置的仿真研究,展示了集中式RAN系统相对于传统分布式系统的优越性,为未来移动网络的设计提供了理论支持和技术依据。
444.exe44444
华为 ArkUI 框架的创新与生态探索.pdf
哈夫曼解压缩算法实现
GLake_ 高效透明的大模型显存管理和优化.pdf
美团 AdHoc 统一查询引擎实践.pdf
基于MVC的.Net技术类门户网站源码 这是一款作者结合工作中积累的一些经验,开发的一套.Net门户类网站,界面十分 精美,功能也相当完善,想了解MVC的可以参考下。 该源码主要包括网站前台和管理后台两大部分,具体功能如下: 网站前台模块:主要包括了各类文章信息的检索、详细浏览、发表留言等功能。 网站后台模块 1、系统:后台首页、修改密码、菜单管理、操作记录、网站设置。 2、后台账号管理:管理员列表、部门管理、角色管理、权限管理。 3、资讯管理:添加文章资讯、所有文章列表、资讯分类管理、文章采集、新闻采集。 4、互动管理:留言管理。5、广告管理:广告列表、添加广告。6、相册管理:相册列表。 源码特色: 1、项目框架基于.Net多层架构+MVC,SQL2012,,需要安装MVC3.0。 2、使用了AutoMapper,和StructureMap,进行依赖注入。 3、归纳和整合了比较全的工具类,一并放入到了Gongap.Common类库中。
huqehufhq1dwqe
【基于Springboot+Vue的设计与实现】高分通过项目,已获导师指导。 本项目是一套基于Springboot+Vue的管理系统,主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的Java学习者。也可作为课程设计、期末大作业 包含:项目源码、数据库脚本、开发说明文档、部署视频、代码讲解视频、全套软件等,该项目可以直接作为毕设使用。 项目都经过严格调试,确保可以运行! 环境说明: 开发语言:Java 框架:springboot,mybatis JDK版本:JDK1.8 数据库:mysql 5.7数据库工具:Navicat11开发软件:eclipse/idea Maven包:Maven3.3
计算机挑战赛2021程序设计赛C++
Java小区物业小程序源码 运行环境:jdk8+tomcat8+mysql5.7+IntelliJ IDEA+maven 使用技术:spring+spring mvc+mybatis+layui 项目描述 微信小程序物业管理系统,微信小程序端包括以下几个模块: 社区公告、报修、信息采集、生活缴费、二手置换 微信小程序后台管理界面可以增删改查社区公告、问卷、问卷问题、问题选项等 在微信小程序前端,用户提交信息后,可在我的界面查看提交的信息,管理员可 以在微信小程序后台管理界面查看所有用户提交的信息。
内容概要:本文介绍了一种基于伴随层析成像技术的‘双差法’(double-difference)方法,用于地震波速度结构反演。这种方法通过构建站间差异测量来减少源签名和系统误差的影响。文章详细探讨了‘双差法’在理论和实际应用中的实施步骤,包括差分时间的计算、不适定性问题的缓解、以及灵敏度比较等内容。数值实验表明,相比于传统的绝对测量,‘双差法’提供了更高分辨率的结构信息。 适合人群:地球物理学家、地震学家、研究人员、地质工程专业的学生和从业人员。 使用场景及目标:本方法适用于需要高精度地层结构解析的研究,如地震活动监测、资源勘探、地壳结构研究等场景。目标是在减少噪声干扰的同时提高成像精度。 其他说明:文中还讨论了聚类分析和正则化方法的应用,以增强问题的稳定性并降低计算成本。同时,‘双差法’对源信号函数错误较为鲁棒,在某些情况下可以更好地分离时相。
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
体适能_2.0.8.apk