0

我正在使用 libtcod 和 c 并且我的移动函数不响应输入,这是函数在被调用时的样子

    TCOD_key_t key;
    move_entity(player.x, player.y, key);

这是实际的源代码

void move_entity(int x, int y, TCOD_key_t key){
    TCOD_sys_check_for_event(TCOD_EVENT_KEY_PRESS, &key, NULL);
    switch(key.vk){
        case TCODK_UP : y--; break;
        case TCODK_DOWN : y++; break;
        case TCODK_RIGHT : x++; break;
        case TCODK_LEFT : x--; break;
        default:break;
    }
}

奇怪的是,当 move_entity 内部的代码被复制到程序响应的主函数中时,这里是主循环

#include "libtcod.h"
#include "move.h"
#include "entity.h"

int main(){
struct Entity player = {40, 25, '@', 100, TCOD_COLOR_LIME};
struct Entity enemy = {20, 35, '&', 50, TCOD_COLOR_RED};
TCOD_console_set_custom_font("terminal12x12_gs_ro.png", TCOD_FONT_LAYOUT_ASCII_INROW, 16, 16);
TCOD_console_init_root(80, 50, "Placeholder title", false, TCOD_RENDERER_SDL);

while(!TCOD_console_is_window_closed()){
    TCOD_key_t key;
    move_entity(player.x, player.y, key);
    TCOD_console_clear(NULL);
    TCOD_console_print(NULL, 1, 1, "Player Health:%d", player.health);
    TCOD_console_print(NULL, 1, 2, "Enemy Health:%d", enemy.health);
    entity_render(player.x, player.y, player.ch, player.forcol);
    entity_render(enemy.x, enemy.y, enemy.ch, enemy.forcol);
    TCOD_console_flush(NULL);
}
return 0;

}

我敢肯定这只是我忽略的一些愚蠢的事情,但它真的让我大吃一惊,我很感激你的帮助:)

*编辑销售商的建议是我编辑的代码

在主循环中调用的代码

 move_entity(&player.x, &player.y);

以及函数中的代码

 void move_entity(int *x, int *y){
     TCOD_key_t key;
     TCOD_sys_wait_for_event(TCOD_EVENT_KEY_PRESS, &key, NULL, false);
     switch(key.vk){
         case TCODK_UP : *y--; break;
         case TCODK_DOWN : *y++; break;
         case TCODK_RIGHT : *x++; break;
         case TCODK_LEFT : *x--; break;
         default:break;
      }
}
4

2 回答 2

1

看来您将 player.x 和 player.y 按值传递给 move_entity() 函数。此函数中对 x 和 y 所做的任何更改都是该函数的局部变量,不会影响 player.x 和 player.y。

您应该更改 move_entity() 函数以接收指向 int 的指针并将 player.x 和 player.y 的地址发送给它,以便它能够更改它们。

于 2014-01-20T13:30:20.427 回答
0
void test(int *x1, int *x2) {
    printf("before modif x1 = %d\n", *x1);
    printf("before modif x2 = %d\n", *x2);

    *x1++;   // equivalent to *(x1 + 1) 
    (*x2)++; // equivalent to *x2 += 1;
}

int main() {
    int x1 = 1;
    int x2 = 1;

    test(&x1, &x2);
    printf("after modif x1 = %d\n", x1);
    printf("after modif x2 = %d\n", x2);

    return 0;
}

请参阅上面的 C 示例以了解发生了什么,您没有以正确的顺序表达优先级,您必须在添加 1 之前先取消引用,否则您将取消引用位于变量之后的内存空间,这没有任何影响。

Output:

before modif x1 = 1
before modif x2 = 1
after modif x1 = 1
after modif x2 = 2
于 2014-03-27T14:26:48.677 回答