`

如何构建自己的游戏框架并且制作游戏(一)(附源码)

阅读更多

原文地址:http://www.cnblogs.com/feifei1010/archive/2012/08/23/2652203.html

 

这个教程就让我们学习怎么用这个游戏框架开发一个简单的空战游戏吧!由于素材有限,都是用的网上的素材。这个游戏可以改造成为空战或者植物大战僵 尸等的养成类型游戏或者更多,原理都差不多。    一个出类拔萃的人总是一个有耐心的人! 一个游戏的制作经常会出现小意外,一个不耐心的人往往会不知所措,我看过李华明他的书上面有介绍游戏框架,而且很详细,但是没有这个全面,现在的很多游戏书籍也很少有关于游戏框架的构建,希望大家可以多借鉴一下,多提提意见!
先上图:

   第一个教程就先搭建属于我们的游戏框架
com.mocn.framework中是框架包
com.mocn.airBottle中是游戏包

 

首先看框架包 中的BaseActivity类,主要用于设置横竖屏,全屏,屏幕的宽高度等等。

?
package com.mocn.framework;
 
import android.R;
import android.app.Activity;
import android.content.pm.ActivityInfo;
import android.os.Bundle;
import android.util.DisplayMetrics;
import android.view.Window;
import android.view.WindowManager;
 
/**
  * Activity的基类,本类中只要设置屏幕为竖屏,全屏,得到屏幕的高度和宽度
  *
  * @author Administrator
  *
  */
public class BaseActivity extends Activity {
          
         /**
          * Activity创建时执行的方法
          */
         @Override
         protected void onCreate(Bundle savedInstanceState) {
                 super .onCreate(savedInstanceState);
                 setFullScreen(); // 设置全屏
                 setLandscape(); // 设置横屏
                 Global.context = this ; // 获取上下文事件
 
                 // 获取屏幕的宽高
                 DisplayMetrics dm = new DisplayMetrics();
                 getWindowManager().getDefaultDisplay().getMetrics(dm);
                 Global.screenWidth = dm.widthPixels; // 获取屏幕的宽度
                 Global.screenHeight = dm.heightPixels; // 获取屏幕的高度
         }
 
         /**
          * 设置为全屏的方法
          */
         public void setFullScreen() {
                 requestWindowFeature(Window.FEATURE_NO_TITLE);
                 getWindow().addFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN);
         }
 
         /**
          * 设置为竖屏的方法
          */
         public void setPortrait() {
                 setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
         }
 
         /**
          * 设置为横屏的方法
          */
         public void setLandscape() {
                 setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
         }
 
}

  BaseView,主要用于设置线程的开关,游戏界面的绘制

?
package com.mocn.framework;
 
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.view.SurfaceHolder;
import android.view.SurfaceHolder.Callback;
import android.view.SurfaceView;
 
/**
  * 游戏界面的基类 SurfaceHolder,线程的开启和关闭,添加組件drawSurfaceView
  *
  * @author Administrator
  *
  */
public abstract class BaseView extends SurfaceView implements Callback,
                 Runnable {
         private SurfaceHolder holder; // SurfaceHolder的引用
         private Thread currentThread; // Thread的引用
         public int sleepTime = 20 ; // 设置睡眠时间
 
         public BaseView(Context context) {
                 super (context);
                 holder = this .getHolder(); // 得到holder对象
                 holder.addCallback( this ); // 得到调函数对象
         }
 
         /**
          * 开启线程的方法
          */
         public void startThread() {
                 currentThread = new Thread( this ); // 得到线程的对象
                 currentThread.start(); // 开启线程
         }
 
         /**
          * 关闭线程的方法
          */
         public void stopThread() {
                 currentThread = null ; // 设置线程为空
         }
 
         /**
          * 当界面改变时执行的方法
          */
         @Override
         public void surfaceChanged(SurfaceHolder holder, int format, int width,
                         int height) {
 
         }
 
         /**
          * 当界面创建时执行的方法
          */
         @Override
         public void surfaceCreated(SurfaceHolder holder) {
                 startThread(); // 开启游戏线程
         }
 
         /**
          * 当游戏被摧毁时执行的方法
          */
         @Override
         public void surfaceDestroyed(SurfaceHolder holder) {
                 stopThread(); // 关闭游戏线程
         }
 
         /**
          * 绘制界面的方法
          *
          * @param canvas
          * @param paint
          */
         public void drawSurfaceView(Canvas canvas, Paint paint) {
                 LayerManager.drawLayerManager(canvas, paint); // 绘制组件
         }
 
         /**
          * 线程的控制方法
          */
         @Override
         public void run() {
                 Canvas canvas;
                 Paint paint = new Paint();
                 while (currentThread != null ) {
                         canvas = holder.lockCanvas();
                         drawSurfaceView(canvas, paint);
                         holder.unlockCanvasAndPost(canvas);
                          try {
                          Thread.sleep(sleepTime);
                          } catch (InterruptedException e) {
                          e.printStackTrace();
                          }
                 }
         }
 
}

  Global类,用于设置一些常量

?
package com.mocn.framework;
 
import android.content.Context;
 
/**
  * 得到屏幕的宽度,高度,Context对象
  *
  * @author Administrator
  *
  */
public class Global
{
         public static Context context; //得到上下文的引用
         public static int screenWidth; //屏幕的宽度
         public static int screenHeight; //屏幕的高度
}

  Layer类,所以绘制组件的基类,里面包括组件的坐标,宽高,以及绘制的方法等

?
package com.mocn.framework;
 
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.Rect;
 
/**
  * 层类,组件的父类,添加组件,设置组件位置,绘制自己, 是所有人物和背景的基类
  *
  * @author Administrator
  *
  */
public abstract class Layer {
         public float x; // 层的x坐标
         public float y; // 层的y坐标
         public int w; // 层的宽度
         public int h; // 层的高度
 
         public Rect src, dst; // 引用Rect类
         public Bitmap bitmap; // 引用Bitmap类
 
         protected Layer(Bitmap bitmap, int w, int h, boolean autoAdd) {
                 this .bitmap = bitmap;
                 this .w = w;
                 this .h = h;
                 src = new Rect();
                 dst = new Rect();
                 if (autoAdd) {
                         LayerManager.addLayer( this ); // 在LayerManager类中添加本组件
                 }
         }
 
         /**
          * 设置组件位置的方法
          *
          * @param x
          * @param y
          */
         public void setPosition( float x, float y) {
                 this .x = x;
                 this .y = y;
         }
 
         /**
          * 绘制自己的抽象接口
          *
          * @param canvas
          * @param paint
          */
         public abstract void drawSelf(Canvas canvas, Paint paint);
}

  BackGroundLayer类,主要用于背景的绘制,可以用做静态的绘制

?
package com.mocn.framework;
 
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Paint;
 
/**
  * 游戏背景组件,在LayerManager中添加游戏背景组件,绘制自己
  *
  * @author Administrator
  *
  */
public class BackGroundLayer extends Layer
{
 
         public BackGroundLayer(Bitmap bitmap, int w, int h)
         {
                 super (bitmap, w, h, true );
         }
 
         @Override
         public void drawSelf(Canvas canvas, Paint paint)
         {
                 src.left = 0 ;
                 src.top = 0 ;
                 src.right = w;
                 src.bottom = h;
 
                 dst.left = ( int ) x;
                 dst.top = ( int ) y;
                 dst.right = dst.left + w;
                 dst.bottom = dst.top + h;
                 canvas.drawBitmap(bitmap, src, dst, paint);
         }
}

  Sprite类,精灵类,用于绘制动态人物

?
package com.mocn.framework;
 
import java.util.Hashtable;
 
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Paint;
 
/**
  * 精灵组件类,添加精灵组件,设置动作,绘制精灵,添加一个动作序列,精灵动作类
  *
  * @author Administrator
  *
  */
public class Sprite extends Layer {
         public int frameIdx; // 当前帧下标
         public int currentFrame = 0 ; // 当前帧
         public Hashtable<String, SpriteAction> actions; // 动作集合
         public SpriteAction currentAction; // 当前动作
 
         public Sprite(Bitmap bitmap, int w, int h, boolean autoAdd) {
                 super (bitmap, w, h, autoAdd);
                 actions = new Hashtable<String, Sprite.SpriteAction>(); // 用Hashtable保存动作集合
         }
 
         /**
          * 设置动作的方法
          *
          * @param actionName
          */
         public void setAction(String actionName) {
                 currentAction = actions.get(actionName); // 从动作集合中得到该动作
         }
 
         /**
          * 绘制精灵的方法
          */
         @Override
         public void drawSelf(Canvas canvas, Paint paint) {
                 if (currentAction != null ) {
                         currentFrame = currentAction.frames[frameIdx]; // 获取当前需要的帧
                 }
                 // 截取图片中需要的帧
                 src.left = currentFrame * w; // 左端宽度:当前帧乘上帧的宽度
                 src.top = 0 ; // 上端高度:0
                 src.right = src.left + w; // 右端宽度:左端宽度加上帧的宽度
                 src.bottom = h; // 下端高度为帧的高度
 
                 // 绘制在界面上,取中心点绘制
                 dst.left = ( int ) x - w / 2 ;
                 dst.top = ( int ) y - h / 2 ;
                 dst.right = dst.left + w;
                 dst.bottom = dst.top + h;
 
                 canvas.drawBitmap(bitmap, src, dst, paint); // 绘制当前帧
                 if (currentAction != null ) {
                         currentAction.nextFrame(); // 绘制下一帧
                 }
         }
 
         /**
          * 添加一个动作集合的方法
          *
          * @param name
          * @param frames
          * @param frameTime
          */
         public void addAction(String name, int [] frames, int [] frameTime) {
                 SpriteAction sp = new SpriteAction(); // 创建SpiteAction的对象
                 sp.frames = frames; // 当前帧的数量,用下标表示
                 sp.frameTime = frameTime; // 每一帧切换的时间
                 actions.put(name, sp); // 将名字为"name"的动作集合,值为sp的动作集合放进acitons中
         }
 
         /**
          * 精灵的移动方法
          *
          * @param dx
          * @param dy
          */
         public void move( int dx, int dy) {
                 this .x += dx;
                 this .y += dy;
         }
 
         // 精灵动作类
         class SpriteAction {
                 public int [] frames; // 该动作的帧序列
                 public int [] frameTime; // 帧序列中每一帧切换对应的时间
                 private long updateTime; // 记录上次失效时间
 
                 /**
                  * 切换到下一帧的方法
                  */
                 public void nextFrame() {
                         if (System.currentTimeMillis() > updateTime) {
                                 frameIdx++; // 帧下标增加
                                 frameIdx %= frames.length;
                                 updateTime = System.currentTimeMillis() + frameTime[frameIdx]; // 切换下一帧所需要的时间
                         }
                 }
         }
}

  LayerManager类,组件管理类,用于管理组件

?
package com.mocn.framework;
 
import java.util.Vector;
 
import android.graphics.Canvas;
import android.graphics.Paint;
 
/**
  * 组件的管理类,用于存放组件,绘制所有组件,添加一个组件,删除一个组件,插入一组件
  *
  *
  * @author Administrator
  *
  */
public class LayerManager {
         public static Vector<Layer> vec = new Vector<Layer>(); // Vector对象用于存放所有组件
 
         /**
          * 绘制所有组件的方法
          *
          * @param canvas
          * @param paint
          */
         public static void drawLayerManager(Canvas canvas, Paint paint) {
                 for ( int i = 0 ; i < vec.size(); i++) {
                         vec.elementAt(i).drawSelf(canvas, paint); // 把存在于Vector对象中的组件绘制出来
                 }
         }
 
         /**
          * 添加一个组件的方法
          *
          * @param layer
          */
         public static synchronized void addLayer(Layer layer) {
                 vec.add(layer); // 在Vector对象中添加此组件
         }
 
         /**
          * 删除一个组件的方法
          *
          * @param layer
          */
         public static synchronized void deleteLayer(Layer layer) {
                 vec.remove(layer); // 在Vector对象中删除此组件
         }
 
         /**
          * 在before指定的位置插入layer,原来对象以及此后的对象依次往后顺延。
          *
          * @param layer
          * @param before
          */
         public static void insert(Layer layer, Layer before) {
                 for ( int i = 0 ; i < vec.size(); i++) { // 遍历Vector对象
                         if (before == vec.elementAt(i)) {
                                 vec.insertElementAt(layer, i); // 在before对象前面插入layer,该对象位于before之上
                                 return ;
                         }
                 }
         }
}

  最后一个,Utilsl类,工具类,包含各种取得图片,碰撞事件的检测等方法

?
package com.mocn.framework;
 
import java.io.IOException;
import java.io.InputStream;
 
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
 
/**
  * 工具类 获得一张图片,判断两个矩形是否相交,判断一个点是否在矩形内
  *
  * @author Administrator
  *
  */
public class Utils {
         /**
          * 获取一张图片的方法
          *
          * @param path
          * @return
          */
         public static Bitmap getBitmap(String path) {
                 try {
                         InputStream is = Global.context.getAssets().open(path);
                         return BitmapFactory.decodeStream(is);
                 } catch (IOException e) {
                         e.printStackTrace();
                 }
                 return null ;
         }
 
         /**
          * 判断两个矩形是否相交的方法
          *
          * @param x
          * @param y
          * @param w
          * @param h
          * @param x2
          * @param y2
          * @param w2
          * @param h2
          * @return
          */
         public static boolean colliseWidth( float x, float y, float w, float h,
                         float x2, float y2, float w2, float h2) {
                 if (x > x2 + w2 || x2 > x + w || y > y2 + h2 || y2 > y + h) {
                         return false ;
                 }
                 return true ;
         }
 
         /**
          * 判断 一个点是否在矩形内的方法
          *
          * @param x
          * @param y
          * @param w
          * @param h
          * @param px
          * @param py
          * @return
          */
         public static boolean inRect( float x, float y, float w, float h, float px,
                         float py) {
                 if (px > x && px < x + w && py > y && py < y + h) {
                         return true ;
                 }
                 return false ;
         }
}

  框架搭建完成,第二篇就是游戏的绘制篇了,如果大家在框架上有什么问题可以问我。
下面附上源码:

  http://files.cnblogs.com/feifei1010/AirBottle.zip

还有看到好多优秀的帖子http://www.apkbus.com/blog-15060-40268.html

分享到:
评论

相关推荐

    Cocos2d-x高级开发教程(捕鱼达人)附源码

    《Cocos2d-x高级开发教程》是一本专注于游戏开发的深入指南,特别是针对捕鱼达人这类游戏的开发。...通过阅读和实践,开发者可以提升自己的C++编程能力,熟悉Cocos2d-x框架,并具备独立开发游戏的能力。

    三电平SVPWM模型的Matlab仿真及其在逆变器性能优化中的应用

    内容概要:本文详细介绍了三电平SVPWM模型在Matlab中的搭建与研究,重点探讨了三电平逆变器的工作原理、性能特点以及参数优化方法。文中不仅解释了三电平逆变器相较于传统两电平逆变器的优势,如更高的电压分辨率和更低的谐波失真,还深入讨论了SVPWM控制策略的具体实现步骤,包括扇区划分、中性点电压平衡、死区时间和波形生成等关键环节。此外,文章还强调了仿真与实际应用之间的差异,指出仿真只是调试的起点而非终点。 适合人群:从事电力电子、自动化控制领域的研究人员和技术人员,尤其是对逆变器建模和仿真相关工作的从业者。 使用场景及目标:适用于需要深入了解三电平逆变器特性和优化控制策略的研究项目,旨在帮助读者掌握基于Matlab的三电平SVPWM模型构建技巧,从而更好地进行逆变器性能评估和改进。 其他说明:文章提供了大量实用的Matlab代码片段,便于读者理解和实践。同时提醒读者关注仿真与现实应用间的细微差别,确保理论成果能够顺利转化为实际效益。

    spring-boot-2.3.9.RELEASE.jar中文文档.zip

    # 压缩文件中包含: 中文文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;

    水利规范-7p倒虹吸工程及渠道防渗衬砌设计图集.zip

    水利规范-7p倒虹吸工程及渠道防渗衬砌设计图集.zip

    JAVAWeb外文文献毕业设计样本.doc

    JAVAWeb外文文献毕业设计样本.doc

    scratch少儿编程逻辑思维游戏源码-我的世界冒险通过 V5.zip

    scratch少儿编程逻辑思维游戏源码-我的世界冒险通过 V5.zip

    scratch少儿编程逻辑思维游戏源码-星之卡比 动画.zip

    scratch少儿编程逻辑思维游戏源码-星之卡比 动画.zip

    spring-data-redis-1.1.0.RELEASE.jar中文-英文对照文档.zip

    # 压缩文件中包含: 中文-英文对照文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文-英文对照文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;

    scratch少儿编程逻辑思维游戏源码-我的世界构建像素立方体.zip

    scratch少儿编程逻辑思维游戏源码-我的世界构建像素立方体.zip

    spring-boot-2.5.1.jar中文文档.zip

    # 压缩文件中包含: 中文文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;

    scratch少儿编程逻辑思维游戏源码-仙人掌内战.zip

    scratch少儿编程逻辑思维游戏源码-仙人掌内战.zip

    scratch少儿编程逻辑思维游戏源码-贪食蛇.zip

    scratch少儿编程逻辑思维游戏源码-贪食蛇.zip

    rocksdbjni-6.29.4.jar中文-英文对照文档.zip

    # 压缩文件中包含: 中文-英文对照文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文-英文对照文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;

    spring-boot-1.3.6.RELEASE.jar中文-英文对照文档.zip

    # 压缩文件中包含: 中文-英文对照文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文-英文对照文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;

    独家分享耗时3个月整理的开发者必备资源库 - 百度/迅雷/夸克三端同步更新

    复制链接到浏览器打开即可,https://link3.cc/diwangluo

    基于Matlab的水果识别程序:融合图像处理与深度学习技术

    内容概要:本文详细介绍了使用Matlab编写的水果识别程序。首先简述了人工智能和机器学习在水果识别领域的应用背景,强调了Matlab作为强大编程环境的优势。接着,文章逐步讲解了水果识别程序的具体实现流程,涵盖数据预处理、特征提取、模型训练以及最终的识别算法实现。每个环节都采用了先进的技术和方法,如图像去噪、大小调整、深度学习算法(特别是卷积神经网络CNN),并通过训练神经网络模型来提升识别精度。此外,还讨论了相关技术手段和技术挑战,展示了Matlab在图像处理和计算机视觉方面的强大能力。 适合人群:对图像处理、机器学习感兴趣的科研人员、学生及工程师。 使用场景及目标:适用于希望深入了解Matlab环境下水果识别程序的设计与实现的研究者;旨在帮助使用者掌握从数据准备到模型部署的一系列技能,为实际项目提供理论支持和技术指导。 其他说明:文中不仅提供了详细的程序实现步骤,还对未来发展方向进行了展望,鼓励更多人参与到水果识别及相关领域的研究中。

    rocksdbjni-6.16.4.jar中文文档.zip

    # 压缩文件中包含: 中文文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;

    西门子S7-300 PLC在汽车生产线自动化中的模块化编程与Profibus DP网络集成方案

    内容概要:本文介绍了西门子S7-300 PLC在某汽车生产线的应用,涵盖了从硬件配置到软件编程的各个方面。硬件部分包括300 CPU、TP700触摸屏、远程ET200站点和Profibus DP网络系统。软件部分涉及PLC程序、HMI界面、IO表和图纸。重点在于模块化编程方法,如模拟量采集、气缸控制、线体阻挡、延时控制和自动换班等功能块的集成。同时,文中提到压力值和位移传感器的数据采集,并通过触摸屏以曲线形式展示。此外,还讨论了梯形图、STL和SCL三种编程语言的混合使用,确保程序结构清晰且易于维护。最后强调了Profibus DP网络在各站点间数据传输中的重要作用。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是对PLC编程和Profibus DP网络有研究兴趣的人群。 使用场景及目标:适用于汽车制造业及其他类似行业,旨在提高生产线的自动化程度和生产效率,确保产品质量。通过对S7-300 PLC的学习和应用,掌握模块化编程技巧和网络通信协议,优化生产线管理。 阅读建议:读者可以通过本文深入了解S7-300 PLC的具体应用场景和技术细节,特别是模块化编程的优势和混合编程的实际操作。同时,关注Profibus DP网络的作用,理解其在网络架构中的重要地位。

    scratch少儿编程逻辑思维游戏源码-数学横版过关游戏.zip

    scratch少儿编程逻辑思维游戏源码-数学横版过关游戏.zip

    spring-boot-1.1.4.RELEASE.jar中文文档.zip

    # 压缩文件中包含: 中文文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;

Global site tag (gtag.js) - Google Analytics