ObjectivelyMVC 0.1.0
Object oriented MVC framework for OpenGL, SDL2 and GNU C
ViewController.h
Go to the documentation of this file.
1/*
2 * ObjectivelyMVC: Object oriented MVC framework for OpenGL, SDL2 and GNU C.
3 * Copyright (C) 2014 Jay Dolan <jay@jaydolan.com>
4 *
5 * This software is provided 'as-is', without any express or implied
6 * warranty. In no event will the authors be held liable for any damages
7 * arising from the use of this software.
8 *
9 * Permission is granted to anyone to use this software for any purpose,
10 * including commercial applications, and to alter it and redistribute it
11 * freely, subject to the following restrictions:
12 *
13 * 1. The origin of this software must not be misrepresented; you must not
14 * claim that you wrote the original software. If you use this software
15 * in a product, an acknowledgment in the product documentation would be
16 * appreciated but is not required.
17 *
18 * 2. Altered source versions must be plainly marked as such, and must not be
19 * misrepresented as being the original software.
20 *
21 * 3. This notice may not be removed or altered from any source distribution.
22 */
23
24#pragma once
25
26#include <Objectively/MutableArray.h>
27
29#include <ObjectivelyMVC/View.h>
30
46typedef struct ViewControllerInterface ViewControllerInterface;
47
54
58 Object object;
59
63 ViewControllerInterface *interface;
64
68 MutableArray *childViewControllers;
69
74
79};
80
84struct ViewControllerInterface {
85
89 ObjectInterface parentInterface;
90
98 void (*addChildViewController)(ViewController *self, ViewController *childViewController);
99
108 void (*handleNotification)(ViewController *self, const Notification *notification);
109
117 ViewController *(*init)(ViewController *self);
118
126 void (*loadView)(ViewController *self);
127
134 void (*loadViewIfNeeded)(ViewController *self);
135
143 void (*moveToParentViewController)(ViewController *self, ViewController *parentViewController);
144
152 void (*removeChildViewController)(ViewController *self, ViewController *childViewController);
153
161
169 void (*respondToEvent)(ViewController *self, const SDL_Event *event);
170
178 void (*setView)(ViewController *self, View *view);
179
187 void (*viewDidAppear)(ViewController *self);
188
196 void (*viewDidDisappear)(ViewController *self);
197
205 void (*viewWillAppear)(ViewController *self);
206
214 void (*viewWillDisappear)(ViewController *self);
215};
216
224
static void respondToEvent(View *self, const SDL_Event *event)
Definition: Control.c:213
static void loadView(ViewController *self)
static void addChildViewController(ViewController *self, ViewController *childViewController)
static void removeChildViewController(ViewController *self, ViewController *childViewController)
#define OBJECTIVELYMVC_EXPORT
Definition: Types.h:39
Views are the fundamental building blocks of ObjectivelyMVC user interfaces.
static void viewWillAppear(ViewController *self)
static void viewWillDisappear(ViewController *self)
static void loadViewIfNeeded(ViewController *self)
static void moveToParentViewController(ViewController *self, ViewController *parentViewController)
static void viewDidAppear(ViewController *self)
static void removeFromParentViewController(ViewController *self)
static void setView(ViewController *self, View *view)
static void handleNotification(ViewController *self, const Notification *notification)
static void viewDidDisappear(ViewController *self)
The Notification type.
Definition: Notification.h:34
A ViewController manages a View and its descendants.
View * view
The main view.
Object object
The superclass.
Class * _ViewController(void)
The ViewController archetype.
ViewControllerInterface * interface
The interface.
ViewController * parentViewController
The parent view controller.
MutableArray * childViewControllers
The child view controllers.
Views are the fundamental building blocks of ObjectivelyMVC user interfaces.
Definition: View.h:133