aboutsummaryrefslogtreecommitdiffstats
path: root/minilibx_opengl_20191021/mlx_opengl.m
diff options
context:
space:
mode:
authorRudy Bousset <rbousset@z2r4p3.le-101.fr>2020-01-17 19:30:15 +0100
committerRudy Bousset <rbousset@z2r4p3.le-101.fr>2020-01-17 19:30:15 +0100
commit3c0434921d80dd99c5afd6272f7aa2d2705218a9 (patch)
tree99154197b71a5c1cde279b6c6cd6050f9264250d /minilibx_opengl_20191021/mlx_opengl.m
parentFirst commit (diff)
download42-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.m57
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);
+}