-
Notifications
You must be signed in to change notification settings - Fork 15
IOS Setup
Once your project is created, import the Cobalt framework in your workspace too by cloning it from github.
Drag and drop the cobalt/sources/iOS/Cobalt folder in your new project's Frameworks folder.
Do not tick the "copy items[...]" option if you are using an under-development version of Cobalt and want your Cobalt code within your Xcode project to be updated as you update Cobalt.
Once your project is created, get the last release, unzip it and import it in your workspace.
That's it.
###Adding a www folder
This folder contains the web part of the application : web pages, styles, javascript libraries. As it is an essential part of the application, we let you define your own folders hierarchy.
Let's start by creating a www folder in your app directory and add it to the project by drag & drop.
Notice that we ticked folder reference to keep files organisation within the bundle file. Do not tick "copy items[...]" option if you want the content to be automatically updated. The created group will appear in blue in Xcode Project Navigator
###Initialise the web side
Once the www folder is linked to the projet, it is time to make it yours, and initialise cobalt on the web side.
Jump to the Web Setup page to do this. Don't forget to come back ;)
###Load your first html page
In your controller header file, import "CobaltViewController.h" and make the ViewController inherit of it and implement CobaltDelegate protocol.
#import "CobaltViewController.h"
@interface ViewController : CobaltViewController<CobaltDelegate>
@end
Then you need to implement methods required by the CobaltDelegate protocol in the ViewController:
#import "ViewController.h"
@implementation ViewController
- (BOOL)onUnhandledMessage:(NSDictionary *)message
{
return NO;
}
- (BOOL)onUnhandledEvent:(NSString *)event withData:(NSDictionary *)data andCallback:(NSString *)callback
{
return NO;
}
- (BOOL)onUnhandledCallback:(NSString *)callback withData:(NSDictionary *)data
{
return NO;
}
@end
####Load the page you want in the didFinishLaunchingWithOptions method
Finally, you have to declare your web folder's location, and load your ViewController from the AppDelegate:
#import "Cobalt.h"
#import "CobaltViewController.h"
@implementation AppDelegate
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
// Override point for customization after application launch.
[Cobalt setResourcePath:myResourcePath]; // default: [NSString stringWithFormat:@"%@%@", [[NSBundle mainBundle] resourcePath], @"/www/"]
UIViewController * viewController = [CobaltViewController getViewControllerForController:@"default" andPage:@"index.html"];
UINavigationController * navigationController = [[UINavigationController alloc] initWithRootViewController:viewController];
self.window.rootViewController = navigationController;
[self.window makeKeyAndVisible];
return YES;
}
By default index.html should be loaded if you don't specify any page.
Add the following in your project prefix file in order to activate Cobalt logs
#define DEBUG_COBALT 1
Cobalt is an Open-Source Hybrid Mobile Framework. Read more about it on the home page or in the documentation
- Introduction to Cobalt navigation
- The cobalt.json file
- native navigation bars
- Handling the Android back button
- Introduction to Cobalt messages
- Publish/Subscribe on the Web side
- Publish/Subscribe on Android
- Publish/Subscribe on iOS
- Web Lifecycle messages
- Pull-To-Refresh and Infinite Scroll
- Custom alerts and Toasts
- LocalStorage
- OpenExternalUrl
- PlatformInfos
- Ajax
- Removing the top bar
- Adding Cobalt to an existing project
- Customizing your hybrid views
- Handle multiple Cobalt webviews on the same screen (TODO)