0

我正在使用自己的逻辑和原始引擎制作快板游戏。我试图使重力和接触阵列中的瓷砖。为了能够从另一个类更改一个类的值,我必须使用引用符号“&”。编译后我收到此错误 ISO C++ 禁止在gravity.cpp 的第29 行进行指针和整数之间的比较 这是gravity 类和gravity.cpp 以及player.h 和player.cpp 的头文件。

重力.h

#ifndef GRAVITY_H
#define GRAVITY_H
#include<allegro.h>
#include<fstream>
#include "Global.h"

class Gravity
{
public:
    Gravity();
    ~Gravity();
    bool canJump,JumpAgain,OnSolidTile,Collision;
    int GravSpeed;
    void LoadMap(const char*filename);
    void Init();
    void Grav_Collision(int &x,int &y,int &x2,int &y2,int Gravspeed,bool canJump,bool JumpAgain,bool OnSolidTile,bool Collision);
    private:
    int loadCounterX,loadCounterY;
    int ColMap[100][100];
    int MapSizeX,MapSizeY;
    };

    #endif // GRAVITY_H

Gravity.cpp Error is on this file #include "gravity.h" // 类的头文件

Gravity::Gravity()
{

}


Gravity::~Gravity()
{

}
void Gravity::Init()
{
 loadCounterX = loadCounterY = 0;
};
void Gravity::Grav_Collision(int &x,int &y,int &x2,int &y2,int Gravspeed,bool canJump,bool JumpAgain,bool OnSolidTile,bool Collision)
{
 for(int i = 0;i < MapSizeX;i++)
 {
     for(int j = 0;j < MapSizeY;j++)
     {
      if(ColMap[i][j] = 1)
      {
          //Collision
          if(&y2 < j*BlockSize)--**This IS where the error is found **--
          {
            Collision = true;       
          }
          else
          {
           Collision = false;    
          }      
      }        
     }        
 }
};
 void Gravity::LoadMap(const char*filename)
 {
 std::ifstream openfile (filename);
 if (openfile.is_open())
 {
 openfile >> MapSizeX >> MapSizeY;
 while (!openfile.eof())
 {
     openfile >> ColMap[loadCounterX][loadCounterY];   
     loadCounterX ++;
     if (loadCounterX >= MapSizeX)
     {
        loadCounterX = 0;
        loadCounterY ++;
     }
 }                       
   loadCounterX = loadCounterY = 0;
 } 
 else
 {
 allegro_message ("NO Collision FILE");    
 } 
 };

播放器.h

#ifndef PLAYER_H
#define PLAYER_H
#include <allegro.h>
#include "Global.h"

class player
{
public:
    player();
    ~player();
    void Init();
    void Update();
    void Draw(BITMAP*buffer,int c1,int c2,int c3);
    void Input();
    //Variable
    int x;
    int x2;
    int y;
    int y2;
    int speed;
    char dir;
    BITMAP*buffer;
    private:
    int c1;
    int c2;
    int c3;
    };

   #endif // PLAYER_H

播放器.cpp

#include "player.h" // class's header file

// class constructor
player::player()
{
// insert your code here
}

// class destructor
player::~player()
{
// insert your code here
}
void player::Init()
{
 x = 9;
 y = 9;
 speed = 1;
 dir = 0;
};
void player::Draw(BITMAP*buffer,int c1,int c2,int c3)
{
 textprintf(buffer, font, x-30, y-10, makecol(255,0,0), "x: %03i", x);
 textprintf(buffer, font, x-30, y-20, makecol(255,0,0), "y: %03i", y);
 rectfill(buffer,x,y,x + 5,y + 5,makecol(c1,c2,c3));
};
void player::Input()
{
 //Input
 if(KLeft && x >= 0)
 {
         dir = 'l'; 
 }
 else if(KRIGHT && x <= SW)
 {
       dir = 'r';      
 }
 else if(KUP && y >= 0)
 {
       dir = 'u';      
 }
 else if(KDOWN && y <= SH)
 {
       dir = 'd';      
 }
 else
 {
       dir = 'e';
 }
 //Output

 if(dir == 'l')
 {
     x += -speed;       
 }
 if(dir == 'r')
 {
   x  += speed;   
 }
 if(dir == 'u')
 {
     y += -speed;       
 }
 if(dir == 'd')
 {
   y  += speed;   
 }

};
void player::Update()
{
 player::Input();

};
4

3 回答 3

1

错误消息清楚地告诉您出了什么问题。

在这一行:

if(&y2 < j*BlockSize)

因为y2是一个整数&y2产生一个指针并且j*BlockSize是一个整数。因此,编译器告诉您比较整数和指针是没有意义的。只需放下&

if(y2 < j*BlockSize)
于 2012-10-25T21:59:10.927 回答
1

在错误行,您可能指的是y2 < j*BlockSize而不是&y2 < j*BlockSize. 您正在将整数与变量 y 的地址(即指针)进行比较。这正是编译器所抱怨的。

于 2012-10-25T21:59:18.827 回答
1

编译器告诉你你需要知道的每一件事,在那一行&y2获取地址,y2你正在将它与它进行比较,j*BlockSize这是一个整数,编译器说你为什么要将地址与数字进行比较?

老实说,我没有阅读您的代码,也不知道您在那里做什么,所以如果您想比较 的值y2j*BlockSize只是 do it as y2 < j*BlockSize,在 C++ 中引用不需要访问器,您可以正常读取/写入它们的值价值

于 2012-10-25T22:00:25.890 回答