Я работаю над проектом игры для бегуна CSFML 2d и хочу реализовать параллакс, чтобы дать игроку представление о скорости.Для этого я хотел бы, чтобы некоторые активы повторялись через sfTexture_setRepeated, но, увы.Он не повторяет их, он расширяет границы пикселей до размера прямоугольника спрайта, который я установил по неизвестной мне причине.
Вот отрывки, касающиеся того, что я пытаюсь сделать:
runner_objects.h
включен в runner_objects.c
typedef enum {
PLAYER ,
OBSTACLE ,
BACKGOUND1 ,
BACKGOUND2 ,
OBJ_COUNT
} objtype_t;
static const char *texture[OBJ_COUNT] = {
"res/undefined.png" ,
"res/undefined.png" ,
"res/bg_clouds.png" ,
"res/bg_mountain.tga" ,
};
static const sfIntRect rect[OBJ_COUNT] = {
{0, 0, 0, 0} ,
{0, 0, 0, 0} ,
{0, 0, 1920*3, 1080} ,
{0, 0, 1920*2, 1080} ,
};
typedef struct object {
// Properties
objtype_t type;
sfTexture *texture;
sfSprite *sprite;
sfIntRect rect;
sfVector2f pos;
// Linked listing
struct object *next;
} obj_t;
runner_objects.c
// Macros like TE_CREATE etc are simply CSFML functions made
// shorter to respect a strict 80 columns limit.
// TE_ = sfTexture, S_ = sfSprite
...
obj_t *object_create (objtype_t type, sfVector2f pos)
{
obj_t *new_obj = malloc(sizeof(obj_t));
if (!new_obj)
return NULL;
new_obj->texture = TE_CREATE_WHOLE(texture[type]);
new_obj->sprite = S_CREATE;
if (!new_obj->texture || !new_obj->sprite)
return object_destroy(&new_obj); // Destroys existing parts and returns NULL
new_obj->type = type;
new_obj->rect = rect[type];
new_obj->pos = pos;
S_SETTEXTURE(new_obj->sprite, new_obj->texture);
if (type == BACKGOUND2 || type == BACKGOUND1)
TE_SETREPREATED(new_obj->texture, true);
S_SETINTRECT(new_obj->sprite, new_obj->rect);
S_SETPOS(new_obj->sprite, new_obj->pos);
new_obj->next = NULL;
return new_obj;
}
...
runner_env.c
Где я настраиваю игровую среду
...
// This function is called by int env_create(env_t **env) which is called
// from my main with the address of my env struct pointer.
int env_create_background(env_t **env)
{
(*env)->objects = object_create(BACKGOUND2, (sfVector2f) {0 , 0});
if (!(*env)->objects)
return mr_puterr(ERR_CREABG); // Puts an error string on STDERR and returns corresponding error code
(*env)->objects->speed = (sfVector2f) { 0, 0 };
(*env)->objects->next = object_create(BACKGOUND1, (sfVector2f) {0 , 0});
if (!(*env)->objects->next)
return mr_puterr(ERR_CREABG);
(*env)->objects->next->speed = (sfVector2f) { 0, 0 };
return NO_ERR;
}
// I know it's very ugly and I'll make an actual linked
// list constructor later this is just for testing for now.
...
и моя структура env_t содержит их, если вам интересно.
typedef struct environment {
sfRenderWindow *window;
sfClock *clock;
sfEvent *evt;
obj_t *objects;
} env_t;
Теперь длявизуальное объяснение проблемы.
Вот скриншот того, что я получаю.
Так что я делаю не так?Что я упустил ?Есть ли способ или приказ установить это, что я мог испортить?