我应该在 Processing 3.5.4 的素描中的哪个位置插入单个字符的精灵?
Where should I insert the sprites of one single character in my sketch on Processing 3.5.4?
我需要为大学目的构建一个简单的游戏,我已经下载了一个游戏角色的一些 png 精灵图,但是我不太熟悉应该在哪里组合所有精灵图来使角色移动.下面是我的基本代码的屏幕截图,它在屏幕上放置了一个背景。我只需要一些关于代码结构的指导。精灵应该放在哪里?
screenshot
如果您的游戏角色已经很好地剪裁并具有透明背景,您应该能够像加载背景一样加载它。
就文件位置而言,它应该在草图文件夹中或草图文件夹中名为 data
的文件夹中:
PImage sprite = loadImage("yourSpriteHere.png");
将加载单字符图像
image(sprite, 0, 0);
会将其呈现在左上角。
- 您可以定义和使用
float x,y
变量,如果按下某个键,您可以更新它的位置
假设您的草图包含 myAwesomeCharacter.png
,基本测试草图如下所示:
// how many pixels per frame the character moves
float charSpeed = 1.5;
// current character position
float charX, charY;
// character image
PImage charImage;
void setup(){
size(300, 300);
// load image
charImage = loadImage("myAwesomeCharacter.png");
}
void draw(){
// update keys
if(keyPressed){
if(keyCode == UP && charY > 0){
charY -= charSpeed;
}
if(keyCode == DOWN && charY < height){
charY += charSpeed;
}
if(keyCode == LEFT && charX > 0){
charX -= charSpeed;
}
if(keyCode == RIGHT && charX < width){
charX += charSpeed;
}
}
// render
background(0);
image(charImage, charX, charY);
}
不清楚您是要俯视图、侧视图还是其他视图:这可能会稍微改变您更新角色移动的方式。
此外,不清楚您是否有单个静态角色图像或 spritesheet 图像,其中一个图像包含多个姿势,例如步行循环动画。如果是这种情况,您可以找到 :它在 p5.js 中,但是将 p5.js 中的小语法更改调整为需要的处理应该是微不足道的:
// full spritesheet
PImage spriteSheet;
// a sprite sampling from sprite sheet
PImage mario;
// 8 frames in the spritesheet
int numSprites = 8;
// each sprite in the sheet has this bounding box
int spriteWidth = 18;
int spriteHeight = 24;
// start frame
int spriteIndex = 1;
void setup(){
size(150,150);
frameRate(24);
noSmooth();
noFill();
spriteSheet = loadImage("mario.png");
// create an image to draw a single sprite into
mario = createImage(spriteWidth,spriteHeight, RGB);
}
// set all pixels (R,G,B,A) to the same value (e.g. clear image with a colour)
void setAllPixels(PImage image,int brightness){
// prep. pixels for manipulation
image.loadPixels();
int numPixels = image.pixels.length;
// loop through all pixels (spriteWidth * spriteHeight * colourChannels(4))
for(int i = 0 ; i < numPixels; i++){
image.pixels[i] = brightness;
}
// commit value changes to image: updates it all in one go, more efficient than set()
image.updatePixels();
}
void draw(){
// clear frame
background(255);
// display the whole sprite sheet
image(spriteSheet,0,0);
// increment sprite index
spriteIndex++;
// reset sprite index if out of bounds
if(spriteIndex >= numSprites){
spriteIndex = 0;
}
// visualise sprite copy rect
rect(spriteIndex * spriteWidth,0,spriteWidth,spriteHeight);
// clear mario image
setAllPixels(mario,color(255));
// copy pixels from sprite sheet into sprite
// copy (source image, source coordinates(x,y,w,h), destination coordiantes (x,y,w,h) )
mario.copy(spriteSheet,
spriteIndex * spriteWidth,0,spriteWidth,spriteHeight,
0 ,0,spriteWidth,spriteHeight);
// display mario sprite
image(mario,mouseX,mouseY+spriteHeight);
}
mario.png数据:

我需要为大学目的构建一个简单的游戏,我已经下载了一个游戏角色的一些 png 精灵图,但是我不太熟悉应该在哪里组合所有精灵图来使角色移动.下面是我的基本代码的屏幕截图,它在屏幕上放置了一个背景。我只需要一些关于代码结构的指导。精灵应该放在哪里?
screenshot
如果您的游戏角色已经很好地剪裁并具有透明背景,您应该能够像加载背景一样加载它。
就文件位置而言,它应该在草图文件夹中或草图文件夹中名为 data
的文件夹中:
PImage sprite = loadImage("yourSpriteHere.png");
将加载单字符图像image(sprite, 0, 0);
会将其呈现在左上角。- 您可以定义和使用
float x,y
变量,如果按下某个键,您可以更新它的位置
假设您的草图包含 myAwesomeCharacter.png
,基本测试草图如下所示:
// how many pixels per frame the character moves
float charSpeed = 1.5;
// current character position
float charX, charY;
// character image
PImage charImage;
void setup(){
size(300, 300);
// load image
charImage = loadImage("myAwesomeCharacter.png");
}
void draw(){
// update keys
if(keyPressed){
if(keyCode == UP && charY > 0){
charY -= charSpeed;
}
if(keyCode == DOWN && charY < height){
charY += charSpeed;
}
if(keyCode == LEFT && charX > 0){
charX -= charSpeed;
}
if(keyCode == RIGHT && charX < width){
charX += charSpeed;
}
}
// render
background(0);
image(charImage, charX, charY);
}
不清楚您是要俯视图、侧视图还是其他视图:这可能会稍微改变您更新角色移动的方式。
此外,不清楚您是否有单个静态角色图像或 spritesheet 图像,其中一个图像包含多个姿势,例如步行循环动画。如果是这种情况,您可以找到
// full spritesheet
PImage spriteSheet;
// a sprite sampling from sprite sheet
PImage mario;
// 8 frames in the spritesheet
int numSprites = 8;
// each sprite in the sheet has this bounding box
int spriteWidth = 18;
int spriteHeight = 24;
// start frame
int spriteIndex = 1;
void setup(){
size(150,150);
frameRate(24);
noSmooth();
noFill();
spriteSheet = loadImage("mario.png");
// create an image to draw a single sprite into
mario = createImage(spriteWidth,spriteHeight, RGB);
}
// set all pixels (R,G,B,A) to the same value (e.g. clear image with a colour)
void setAllPixels(PImage image,int brightness){
// prep. pixels for manipulation
image.loadPixels();
int numPixels = image.pixels.length;
// loop through all pixels (spriteWidth * spriteHeight * colourChannels(4))
for(int i = 0 ; i < numPixels; i++){
image.pixels[i] = brightness;
}
// commit value changes to image: updates it all in one go, more efficient than set()
image.updatePixels();
}
void draw(){
// clear frame
background(255);
// display the whole sprite sheet
image(spriteSheet,0,0);
// increment sprite index
spriteIndex++;
// reset sprite index if out of bounds
if(spriteIndex >= numSprites){
spriteIndex = 0;
}
// visualise sprite copy rect
rect(spriteIndex * spriteWidth,0,spriteWidth,spriteHeight);
// clear mario image
setAllPixels(mario,color(255));
// copy pixels from sprite sheet into sprite
// copy (source image, source coordinates(x,y,w,h), destination coordiantes (x,y,w,h) )
mario.copy(spriteSheet,
spriteIndex * spriteWidth,0,spriteWidth,spriteHeight,
0 ,0,spriteWidth,spriteHeight);
// display mario sprite
image(mario,mouseX,mouseY+spriteHeight);
}
mario.png数据:
