run MLX42 test
This commit is contained in:
parent
ac637c6f67
commit
3f7bd0cf11
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
fdf
|
||||
*.a
|
||||
*.o
|
||||
79
Makefile
79
Makefile
@ -0,0 +1,79 @@
|
||||
# **************************************************************************** #
|
||||
# #
|
||||
# ::: o_ :::::: ::: #
|
||||
# Makefile :+: / :+::+: :+: #
|
||||
# +:+ > +:++:+ +:+ #
|
||||
# By: whaffman <whaffman@student.codam.nl> +#+ +:+ +#++#++:++#++ #
|
||||
# +#+ +#+#+ +#++#+ +#+ \o/ #
|
||||
# Created: 2024/10/15 11:48:46 by whaffman #+#+# #+#+# #+# #+# | #
|
||||
# Updated: 2024/11/07 15:28:08 by whaffman ### ### ### ### / \ #
|
||||
# #
|
||||
# **************************************************************************** #
|
||||
|
||||
NAME = fdf
|
||||
|
||||
SRC_PATH = src
|
||||
INC_PATH = inc
|
||||
LIB_PATH = lib
|
||||
|
||||
LIBFT_PATH = $(LIB_PATH)/libft
|
||||
LIBFT_INC_PATH = $(LIBFT_PATH)/inc
|
||||
LIBFT = $(LIBFT_PATH)/libft.a
|
||||
|
||||
MLX42_PATH = $(LIB_PATH)/MLX42
|
||||
MLX42_INC_PATH = $(MLX42_PATH)/include/MLX42
|
||||
MLX42 = $(MLX42_PATH)/build/libmlx42.a
|
||||
|
||||
OBJ_PATH = obj
|
||||
|
||||
VPATH = src
|
||||
SOURCES = fdf.c
|
||||
|
||||
OBJECTS = $(addprefix $(OBJ_PATH)/, $(SOURCES:.c=.o))
|
||||
|
||||
CC = cc
|
||||
RM = rm -rf
|
||||
|
||||
INCLUDES = -I./$(INC_PATH) -I./$(LIBFT_INC_PATH) -I./$(MLX42_INC_PATH)
|
||||
CFLAGS = -Wall -Wextra -Werror
|
||||
|
||||
UNAME_S := $(shell uname -s)
|
||||
ifeq ($(UNAME_S),Linux)
|
||||
LDLIBS := -L$(LIBFT_PATH) -lft -L$(MLX42_PATH)/build -lmlx42 -ldl -lglfw -pthread -lm
|
||||
endif
|
||||
|
||||
all: $(NAME)
|
||||
|
||||
$(MLX42): $(MLX42_PATH)
|
||||
cmake $(MLX42_PATH) -B $(MLX42_PATH)/build;
|
||||
make -C$(MLX42_PATH)/build -j4;
|
||||
|
||||
$(MLX42_DIR):
|
||||
git submodule add https://github.com/codam-coding-college/MLX42.git $(MLX42_PATH);
|
||||
|
||||
$(LIBFT): $(LIBFT_PATH)
|
||||
$(MAKE) -sC $(LIBFT_PATH)
|
||||
|
||||
$(LIBFT_PATH):
|
||||
git submodule add git@duinvoetje.nl:willem/libft.git $(LIBFT_PATH)
|
||||
|
||||
$(NAME): $(MLX42) $(LIBFT) $(OBJECTS)
|
||||
$(CC) $(CFLAGS) $(OBJECTS) $(LDLIBS) -o $(NAME)
|
||||
|
||||
$(OBJ_PATH):
|
||||
mkdir -p $@
|
||||
|
||||
$(OBJ_PATH)/%.o: %.c $(LIBFT) $(MLX42) | $(OBJ_PATH)
|
||||
$(CC) $(CFLAGS) $(INCLUDES) -c $< -o $@
|
||||
|
||||
clean:
|
||||
$(RM) $(OBJECTS) $(OBJ_PATH)
|
||||
$(MAKE) -C libft clean
|
||||
|
||||
fclean: clean
|
||||
$(RM) $(NAME)
|
||||
$(MAKE) -C libft fclean
|
||||
|
||||
re: fclean all
|
||||
|
||||
.PHONY: all clean fclean re
|
||||
89
fdf.c
Normal file
89
fdf.c
Normal file
@ -0,0 +1,89 @@
|
||||
|
||||
// -----------------------------------------------------------------------------
|
||||
// Codam Coding College, Amsterdam @ 2022-2023 by W2Wizard.
|
||||
// See README in the root project for more information.
|
||||
// -----------------------------------------------------------------------------
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <stdbool.h>
|
||||
#include "MLX42.h"
|
||||
|
||||
#define WIDTH 512
|
||||
#define HEIGHT 512
|
||||
|
||||
static mlx_image_t* image;
|
||||
|
||||
// -----------------------------------------------------------------------------
|
||||
|
||||
int32_t ft_pixel(int32_t r, int32_t g, int32_t b, int32_t a)
|
||||
{
|
||||
return (r << 24 | g << 16 | b << 8 | a);
|
||||
}
|
||||
|
||||
void ft_randomize(void* param)
|
||||
{
|
||||
(void)param;
|
||||
for (uint32_t i = 0; i < image->width; ++i)
|
||||
{
|
||||
for (uint32_t y = 0; y < image->height; ++y)
|
||||
{
|
||||
uint32_t color = ft_pixel(
|
||||
rand() % 0xFF, // R
|
||||
rand() % 0xFF, // G
|
||||
rand() % 0xFF, // B
|
||||
rand() % 0xFF // A
|
||||
);
|
||||
mlx_put_pixel(image, i, y, color);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void ft_hook(void* param)
|
||||
{
|
||||
mlx_t* mlx = param;
|
||||
|
||||
if (mlx_is_key_down(mlx, MLX_KEY_ESCAPE))
|
||||
mlx_close_window(mlx);
|
||||
if (mlx_is_key_down(mlx, MLX_KEY_UP))
|
||||
image->instances[0].y -= 5;
|
||||
if (mlx_is_key_down(mlx, MLX_KEY_DOWN))
|
||||
image->instances[0].y += 5;
|
||||
if (mlx_is_key_down(mlx, MLX_KEY_LEFT))
|
||||
image->instances[0].x -= 5;
|
||||
if (mlx_is_key_down(mlx, MLX_KEY_RIGHT))
|
||||
image->instances[0].x += 5;
|
||||
}
|
||||
|
||||
// -----------------------------------------------------------------------------
|
||||
|
||||
int32_t main(void)
|
||||
{
|
||||
mlx_t* mlx;
|
||||
|
||||
// Gotta error check this stuff
|
||||
if (!(mlx = mlx_init(WIDTH, HEIGHT, "MLX42", true)))
|
||||
{
|
||||
puts(mlx_strerror(mlx_errno));
|
||||
return(EXIT_FAILURE);
|
||||
}
|
||||
if (!(image = mlx_new_image(mlx, 128, 128)))
|
||||
{
|
||||
mlx_close_window(mlx);
|
||||
puts(mlx_strerror(mlx_errno));
|
||||
return(EXIT_FAILURE);
|
||||
}
|
||||
if (mlx_image_to_window(mlx, image, 0, 0) == -1)
|
||||
{
|
||||
mlx_close_window(mlx);
|
||||
puts(mlx_strerror(mlx_errno));
|
||||
return(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
mlx_loop_hook(mlx, ft_randomize, mlx);
|
||||
mlx_loop_hook(mlx, ft_hook, mlx);
|
||||
|
||||
mlx_loop(mlx);
|
||||
mlx_terminate(mlx);
|
||||
return (EXIT_SUCCESS);
|
||||
}
|
||||
Loading…
Reference in New Issue
Block a user