diff options
author | Rudy Bousset <rbousset@z2r4p3.le-101.fr> | 2020-01-17 19:30:15 +0100 |
---|---|---|
committer | Rudy Bousset <rbousset@z2r4p3.le-101.fr> | 2020-01-17 19:30:15 +0100 |
commit | 3c0434921d80dd99c5afd6272f7aa2d2705218a9 (patch) | |
tree | 99154197b71a5c1cde279b6c6cd6050f9264250d /minilibx_opengl_20191021/mlx_opengl.m | |
parent | First commit (diff) | |
download | 42-cub3d-3c0434921d80dd99c5afd6272f7aa2d2705218a9.tar.gz 42-cub3d-3c0434921d80dd99c5afd6272f7aa2d2705218a9.tar.bz2 42-cub3d-3c0434921d80dd99c5afd6272f7aa2d2705218a9.tar.xz 42-cub3d-3c0434921d80dd99c5afd6272f7aa2d2705218a9.tar.zst 42-cub3d-3c0434921d80dd99c5afd6272f7aa2d2705218a9.zip |
Added minilibX
Diffstat (limited to '')
-rw-r--r-- | minilibx_opengl_20191021/mlx_opengl.m | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/minilibx_opengl_20191021/mlx_opengl.m b/minilibx_opengl_20191021/mlx_opengl.m new file mode 100644 index 0000000..554d79b --- /dev/null +++ b/minilibx_opengl_20191021/mlx_opengl.m @@ -0,0 +1,57 @@ +// mlx_opengl.m + +#import <Cocoa/Cocoa.h> +#import <OpenGL/gl3.h> +#import <AppKit/NSOpenGLView.h> + +#include <stdio.h> + +#include "mlx_int.h" +#include "mlx_new_window.h" + + + + + +NSOpenGLPixelFormatAttribute pfa_attrs_opengl[] = + { + NSOpenGLPFADepthSize, 32, + NSOpenGLPFADoubleBuffer, + NSOpenGLPFAOpenGLProfile, NSOpenGLProfileVersion4_1Core, + 0 + }; + + + +void *mlx_new_opengl_window(mlx_ptr_t *mlx_ptr, int size_x, int size_y, char *title) +{ + mlx_win_list_t *newwin; + NSString *str; + + if ((newwin = malloc(sizeof(*newwin))) == NULL) + return ((void *)0); + newwin->img_list = NULL; + newwin->next = mlx_ptr->win_list; + newwin->nb_flush = 0; + newwin->pixmgt = 0; + mlx_ptr->win_list = newwin; + + NSRect windowRect = NSMakeRect(100, 100, size_x, size_y); + str = [NSString stringWithCString:title encoding:NSASCIIStringEncoding]; + newwin->winid = [[MlxWin alloc] initWithRect:windowRect andTitle:str pfaAttrs:pfa_attrs_opengl]; + + return ((void *)newwin); +} + + +int mlx_opengl_swap_buffers(mlx_win_list_t *win_ptr) +{ + [(id)(win_ptr->winid) flushGLContext]; + return (0); +} + +int mlx_opengl_window_set_context(mlx_win_list_t *win_ptr) +{ + [(id)(win_ptr->winid) selectGLContext]; + return (0); +} |