今天了解了下项目创建向导生成的代码。这是上篇工具自动生成的代码
为了好理解,我加上注释
package com.me.mygdxgame;
import com.badlogic.gdx.ApplicationListener;
import com.badlogic.gdx.Gdx;
import com.badlogic.gdx.graphics.GL20;
import com.badlogic.gdx.graphics.OrthographicCamera;
import com.badlogic.gdx.graphics.Texture;
import com.badlogic.gdx.graphics.Texture.TextureFilter;
import com.badlogic.gdx.graphics.g2d.Sprite;
import com.badlogic.gdx.graphics.g2d.SpriteBatch;
import com.badlogic.gdx.graphics.g2d.TextureRegion;
public class MyGdxGame implements ApplicationListener {
//摄像机
private OrthographicCamera camera;
//纹理渲染类,它收集绘图的信息,并一次性地发送给GPU绘制出来,本质上是对 OpenGL的封装。
// 每次调用spriteBatch都必须以begin开头,end结尾
private SpriteBatch batch;
//纹理
private Texture texture;
//精灵类
private Sprite sprite;
/**
* 在create方法中初始化参数
*/
@Override
public void create() {
//获取屏幕的大小
float w = Gdx.graphics.getWidth();
float h = Gdx.graphics.getHeight();
//摄像机,可以想象成我们的眼睛
camera = new OrthographicCamera(1,h/w);
batch = new SpriteBatch();
//获取纹理,这是以android的assets目录为根目录
texture = new Texture(Gdx.files.internal("data/libgdx.png"));
//跟Opengles有关,暂时先不理它
texture.setFilter(TextureFilter.Linear, TextureFilter.Linear);
//可以打开libgdx.png看下。它上面是一个图片,下面一片空白。整个图片尺寸为 512*512
//打开TextureRegion的构造方法我们看下它的说明
/** @param width The width of the texture region. May be negative to flip the sprite when drawn.
* @param height The height of the texture region. May be negative to flip the sprite when drawn. */
//其实就是截图嘛
TextureRegion region = new TextureRegion(texture, 0, 0, 512, 275);
//初始化精灵类
sprite = new Sprite(region);
//设置精灵类的大小
sprite.setSize(0.9f, 0.9f * sprite.getHeight() / sprite.getWidth());
//它的原点,根据代码可以看出,其实就是中心位置。
sprite.setOrigin(sprite.getWidth()/2, sprite.getHeight()/2);
//设置它的位置
sprite.setPosition(-sprite.getWidth()/2, -sprite.getHeight()/2);
}
/**
* 释放资源
* libgdx有些资源是需要我们手动释放的。
* 这个一定要注意,可以看下那些类实现了dispose接口
*/
@Override
public void dispose() {
batch.dispose();
texture.dispose();
}
/**
* 核心方法 渲染
* 按我的理解,它就是一个无限循环的方法,就像个do while循环一样
* 这个方法被不停循环执行。
*/
@Override
public void render() {
Gdx.gl.glClearColor(1, 1, 1, 1);
Gdx.gl.glClear(GL20.GL_COLOR_BUFFER_BIT);
//设置投影矩阵到SpriteBatch
batch.setProjectionMatrix(camera.combined);
batch.begin();
sprite.draw(batch);
batch.end();
}
//下面的方法看字面意思都可以理解
@Override
public void resize(int width, int height) {
}
@Override
public void pause() {
}
@Override
public void resume() {
}
}
我对上面代码归纳如下
先初始化相关参数,加载纹理,然后使用sprite类绘制出图形。挺简单的。
按照惯例,来自己写个helloworld吧
新建一个MyGame类如下:
package com.me.mygdxgame;
import com.badlogic.gdx.ApplicationListener;
import com.badlogic.gdx.Gdx;
import com.badlogic.gdx.graphics.GL20;
import com.badlogic.gdx.graphics.g2d.BitmapFont;
import com.badlogic.gdx.graphics.g2d.SpriteBatch;
public class MyGame implements ApplicationListener {
private SpriteBatch batch;
private BitmapFont bitmapFont;
@Override
public void create() {
batch = new SpriteBatch();
//文字绘制
bitmapFont = new BitmapFont();
}
@Override
public void render() {
//这个经常出现的代码就是opengl ES的清屏方法
Gdx.gl.glClear(GL20.GL_COLOR_BUFFER_BIT);
//使用一种颜色填充屏幕
//前三个是屏幕颜色的参数,最后一个是透明度,注意颜色不是我们熟悉的RGB
Gdx.gl.glClearColor(0.57f, 0.40f, 0.55f, 1.0f);
batch.begin();
bitmapFont.draw(batch, "hello libgdx!......", Gdx.graphics.getWidth() * 0.4f, Gdx.graphics.getHeight() / 2);
batch.end();
}
@Override
public void dispose() {
batch.dispose();
bitmapFont.dispose();
}
@Override
public void resize(int width, int height) {
}
@Override
public void pause() {
}
@Override
public void resume() {
}
}
修改android中的MainActivity类如下:
package com.me.mygdxgame;
import android.os.Bundle;
import com.badlogic.gdx.backends.android.AndroidApplication;
import com.badlogic.gdx.backends.android.AndroidApplicationConfiguration;
public class MainActivity extends AndroidApplication {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
AndroidApplicationConfiguration cfg = new AndroidApplicationConfiguration();
initialize(new MyGame(), cfg);
}
}
运行一下,哈哈是不是很有成就感。很简单的嘛。
解释下BitmapFont,单独看名字就知道和字体有关的。draw方法中最后两个参数其实就是绘制的开始位置。我们打开源码看下它的默认构造方法
/** Creates a BitmapFont using the default 15pt Arial font included in the libgdx JAR file. This is convenient to easily display
* text without bothering with generating a bitmap font. */
public BitmapFont () {
this(Gdx.files.classpath("com/badlogic/gdx/utils/arial-15.fnt"),
Gdx.files.classpath("com/badlogic/gdx/utils/arial-15.png"), false, true);
}
打开源码中的两个文件看看一个是描述性文件,一个是个图片。描述性文件太长就不贴了。
我们看图片
原来如此。其实根本不是什么字体文件,只是一个图片而已。熟悉web前端的同学一定不陌生这种处理方法。
我好像没有看到一个汉字。修改源码中的hello libgdx 为中文“你好 libgdx!”运行下试试。
不出所料,根本没有你好两个字。这说明一个问题。libgdx不是中国人开发的
虽然作者不是中国人,但是作者还是给我们提供了解决的办法(参考官方开发者手册)
使用windows命令行进入我们编译好的libgdx的dist目录。如果不知道windows命令行是什么意思的同学,你只能百度了。
IDEA本身就可以直接打开命令行
赞一个
//输入如下命令
java -cp gdx.jar;gdx-natives.jar;gdx-backend-lwjgl.jar;gdx-backend-lwjgl-natives.jar;extensions\gdx-tools\gdx-tools.jar com.badlogic.gdx.tools.hiero.Hiero
好了,出现如下窗口。我们修改下。然后保存为myfont文件
拷贝生成的两个文件到android下的assets/data/font目录。
font是我新建的目录。我们要养成好的编程习惯,不能乱扔东西。
好了,但是如何加载呢。我想起了前面项目工具自动生成的那段代码。加载纹理那段。
试试吧,修改create方法中的代码如下:
public void create() {
batch = new SpriteBatch();
//文字绘制
bitmapFont = new BitmapFont(Gdx.files.internal("data/font/myfont.fnt"),
Gdx.files.internal("data/font/myfont.png"), false);
}
刚才我不是修改成“你好 libgdx”了吗,现在再试试看看怎么样
好了,没问题了。就这么简单。哈哈,我太聪明了。
好了今天到此为止。
本章代码:http://pan.baidu.com/s/1i3l1Uxn
- 大小: 21.3 KB
- 大小: 25.9 KB
- 大小: 103.3 KB
- 大小: 40.4 KB
- 大小: 10.6 KB
分享到:
相关推荐
通常,这需要使用第三方库,如`tritao-gif`或者`libgdx-gif`,这些库将GIF数据解析为一系列的帧,然后可以被LibGDX的`Animation`类使用。`Animation`类是LibGDX中用于管理序列帧动画的关键组件,它可以处理帧间隔...
libGDX学习记录(二)阶段源码 展示TexturePacker合成的图片,详细地址: https://blog.csdn.net/weixin_47450795/article/details/110037945
这个“libgdx学习资料”压缩包包含了丰富的资源,帮助你深入理解和掌握LibGDX的各个方面。 1. **基础知识**: - LibGDX是基于OpenGL的,它提供了对底层图形处理的高级抽象,简化了游戏渲染。 - 它的核心组件包括...
在LibGDX中,`Skin`类是一个非常重要的工具,它主要用于管理UI组件的外观和感觉,包括纹理、字体和样式。`Skin`类使得游戏开发者能够轻松地定义和应用用户界面(UI)的主题,从而提高游戏的视觉质量。 `Skin`类主要...
1. **使用ShapeRenderer**:LibGDX提供了`ShapeRenderer`类,用于绘制基本形状,如线条、矩形、圆等。在`HelloWorldScreen`中,你需要创建一个`ShapeRenderer`实例,并在`render()`方法中使用它。 ```java private ...
Libgdx的`SpriteBatch`类是用于绘制2D图形的主要工具,包括文本。首先,你需要开始一个新的批次操作,然后调用`BitmapFont.draw()`方法: ```java SpriteBatch batch = new SpriteBatch(); batch.begin(); myFont....
通过学习和实践这个"Libgdx专题系列 UI篇",你将掌握如何利用TWL库和TableLayout在Libgdx中创建出高效、美观的用户界面,为你的游戏或应用增添更多互动性和吸引力。记得不断尝试和迭代,让UI设计适应你的项目需求,...
### libgdx学习文档知识点详解 #### 一、libgdx概述 libgdx是一款功能强大的跨平台游戏开发框架,支持2D与3D游戏的创建。它旨在为开发者提供一套全面的API,覆盖从图形渲染到物理模拟的广泛领域。libgdx的亮点在于...
**libGDX学习记录(二)完整源码 水果落地** libGDX是一个开源的游戏开发框架,专为跨平台游戏设计,支持Windows、Linux、Mac OS X、Android以及HTML5。它提供了丰富的功能,包括图形渲染、音频处理、输入管理、...
通过深入学习和实践,开发者可以利用LibGDX创造出具有丰富视觉效果和互动性的2D游戏世界。提供的文件“LibgdxText_3”可能是这个专题系列的源代码或文档,可以帮助进一步理解和实现斜45°地图的细节。
在这一系列的教程中,你将逐步学习如何使用上述技术和工具,从创建基本的Game类开始,搭建游戏结构,到设计游戏逻辑,直至完成一个功能完备的游戏。每个文档(game1至game11)都将深入讲解一个具体主题,帮助你逐步...
本专题系列将深入探讨Libgdx的使用方法,帮助你掌握这个工具并开始你的游戏开发之旅。 在“Libgdx专题系列第一篇 第一节”中,我们将着重介绍Libgdx的基础知识和环境搭建。首先,你需要下载并安装Java Development ...
通过研究"RunBigAdventure"的源代码,开发者可以学习到如何运用LibGDX的各种工具和技巧来构建一个跑酷游戏。从游戏逻辑到视觉表现,从物理模拟到用户交互,每个环节都体现了LibGDX的强大功能。对于初学者,这是一个...
LibGDX是一个强大的开源游戏开发框架,用于创建跨平台的游戏。Net模块是LibGDX库的一部分,它提供了网络通信的功能,让游戏可以与其他设备或服务器进行数据交换。本篇文章将深入探讨如何在LibGDX中使用Net模块进行...
快速构建libgdx项目,一键运行自己的游戏项目。··········
在libGDX中,照相机(Camera)是用于控制场景视口和视角的重要工具。本文将深入探讨libGDX中的照相机使用,包括其基本概念、常见类型以及如何在实际项目中应用。 1. 基本概念: 照相机在libGDX中主要由`...
libGDX学习记录(一)源码,搭建一个桌面端和android端的libGDX框架,展示图片。 详细地址:https://blog.csdn.net/weixin_47450795/article/details/110003413
在这个“Mario的小例子”中,我们将探讨如何利用LibGDX中的Actor类来构建游戏场景,特别是如何模拟经典的马里奥游戏元素。Actor类是LibGDX舞台(Stage)系统的基础,它允许开发者创建具有交互性的游戏对象。 Actor...
2. **SpriteBatch**: 这个类用于高效地绘制2D图形,包括精灵、纹理和文字。它允许开发者一次性绘制多个图形,减少了渲染时的上下文切换。 3. **Camera**: LibGDX提供了多种相机类,如OrthographicCamera和...