我应该在 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数据:

