对许多人来说这似乎是显而易见的,但是我被困住了,我找不到任何帮助我的教程,所以在这里找到答案会很棒。
我尝试在RTS游戏中制作一个像矩形一样的矩形,所以说一个动态选择框,但它无法正常工作。 如果有人列出了每个步骤来创建像这样的框
,那也就足够了(不要怀疑我是c +的新手)
Mouse.h:
#ifndef MOUSE_H_
#define MOUSE_H_
class Mouse {
public:
bool leftButtonDown = false;
bool mouseMoves = false;
struct MouseCoords {
int x = -1;
int y = -1;
};
MouseCoords start_coords;
MouseCoords move_coords;
Mouse(){}
void setState(Uint32 eventType, SDL_Event event){
if ( eventType == SDL_MOUSEBUTTONDOWN) {
this->leftButtonDown = true;
SDL_GetMouseState( &this->start_coords.x, &this->start_coords.y );
}
if ( eventType == SDL_MOUSEBUTTONUP ) {
this->leftButtonDown = false;
}
if ( eventType == SDL_MOUSEMOTION ) {
this->mouseMoves = true;
this->move_coords.x = event.motion.x;
this->move_coords.y = event.motion.y;
} else {
this->mouseMoves = false;
}
}
/**
* Provides coordinates when mousebutton down
*/
MouseCoords getCoordinates(){
return move_coords;
}
/**
* Refresh the coordinates. MUST be called after Mouse::clearCoordinates();
*/
void clearCoordinates(){
this->move_coords.x = -1;
this->move_coords.y = -1;
}
/**
* Creates selector rect, call this in the render loop
*/
void createSelectBox(SDL_Renderer *renderer){
if(this->leftButtonDown) {
Block rect(
this->start_coords.x,
this->move_coords.y,
this->start_coords.y -this->move_coords.y ,
this->move_coords.x - this->start_coords.x
);
rect.draw( renderer );
this->clearCoordinates();
}
}
};
#endif
Block.h
#ifndef BLOCK_H_
#define BLOCK_H_
/**
* Standard Class which can be used to build a player, enemy, or something similar
*/
class Block{
SDL_Rect rect;
public:
Block(int x=10, int y=10, int w=10, int h=10, int filled=true){
rect.x = x;
rect.y = y;
rect.w = w;
rect.h = h;
}
/**
* draw with the given rendererer
*/
void draw(SDL_Renderer *renderer){
SDL_SetRenderDrawColor( renderer , 200 , 155 , 255 , 255);
SDL_RenderDrawRect( renderer, &rect );
SDL_RenderPresent( renderer );
}
bool framed(){
return 0;
}
};
#endif
然后在我的main.cpp
中SDL_Window *window;
SDL_Renderer *renderer;
Mouse mouse;
Block rect;
void renderWindow(){
window = SDL_CreateWindow("commanding rects", 100, 100, 700, 600, 0);
renderer = SDL_CreateRenderer(window, -1, 0);
}
void renderGame(Mouse mouse){
SDL_RenderSetLogicalSize( renderer, 400, 300 );
SDL_SetRenderDrawColor( renderer, 0, 0, 0, 0);
SDL_RenderClear( renderer );
SDL_RenderPresent( renderer );
mouse.createSelectBox( renderer );
}
void gameLoop(){
bool game_run = true;
while (game_run) {
SDL_Event event;
while( SDL_PollEvent(&event)){
if ( event.type == SDL_QUIT ) {
game_run = false;
}
mouse.setState(event.type, event);
}
renderGame(mouse);
SDL_Delay( 15 );
}
}
int main(){
renderWindow();
gameLoop();
return 0;
}
答案 0 :(得分:1)
我在这里发现了一个问题:
void createSelectBox(SDL_Renderer *renderer){
if(this->leftButtonDown) {
Block rect(this->mousedown_coords.x,
this->mousemove_coords.y,
this->mousedown_coords.y - this->mousemove_coords.y,
this->mousemove_coords.x - this->mousedown_coords.x);
在这段代码中,无论鼠标坐标的值是多少,您都要将矩形的宽度和高度设置为0。由于你正在绘制一个边界框,我想你要存储两组x,y坐标,一个用于按下鼠标按钮,另一个用于释放它时。
答案 1 :(得分:0)
我终于发现了我做错了什么。
我正在检索绘制矩形的错误起点。
当触发mousedown时,我必须得到event.button.x
而不是GetMouseState
这是更新的Mouse.h
#ifndef MOUSE_H_
#define MOUSE_H_
class Mouse {
public:
bool leftButtonDown = false;
bool mouseMoves = false;
struct MouseCoords {
int x = -1;
int y = -1;
};
MouseCoords start_coords;
MouseCoords move_coords;
Mouse(){}
void setState(Uint32 eventType, SDL_Event event){
if ( eventType == SDL_MOUSEBUTTONDOWN) {
this->leftButtonDown = true;
this->start_coords.x = event.button.x;
this->start_coords.y = event.button.y;
}
if ( eventType == SDL_MOUSEBUTTONUP ) {
this->leftButtonDown = false;
}
if ( eventType == SDL_MOUSEMOTION ) {
this->move_coords.x = event.motion.x;
this->move_coords.y = event.motion.y;
}
}
/**
* Provides coordinates when mousebutton down
*/
MouseCoords getCoordinates(){
return move_coords;
}
/**
* Creates selector rect, call this in the render loop
*/
void createSelectBox(SDL_Renderer *renderer){
if(this->leftButtonDown) {
float width = this->move_coords.x - this->start_coords.x;
float height = this->start_coords.y - this->move_coords.y;
float x = this->start_coords.x ;
float y = this->move_coords.y;
Block rect(x, y,width, height);
rect.draw( renderer );
}
}
};
#endif