.. _OpenCViOSHelloWorld: OpenCV iOS Hello ******************************* Goal ==== In this tutorial we will learn how to: .. container:: enumeratevisibleitemswithsquare * Link OpenCV framework with Xcode * How to write simple Hello World application using OpenCV and Xcode. *Linking OpenCV iOS* ====================== Follow this step by step guide to link OpenCV to iOS. 1. Create a new XCode project. 2. Now we need to link *opencv2.framework* with Xcode. Select the project Navigator in the left hand panel and click on project name. 3. Under the TARGETS click on Build Phases. Expand Link Binary With Libraries option. 4. Click on Add others and go to directory where *opencv2.framework* is located and click open 5. Now you can start writing your application. .. image:: images/linking_opencv_ios.png :alt: OpenCV iOS in Xcode :align: center *Hello OpenCV iOS Application* =============================== Now we will learn how to write a simple Hello World Application in Xcode using OpenCV. .. container:: enumeratevisibleitemswithsquare * Link your project with OpenCV as shown in previous section. * Open the file named *NameOfProject-Prefix.pch* ( replace NameOfProject with name of your project) and add the following lines of code. .. code-block:: cpp #ifdef __cplusplus #import <opencv2/opencv.hpp> #endif .. image:: images/header_directive.png :alt: header :align: center .. container:: enumeratevisibleitemswithsquare * Add the following lines of code to viewDidLoad method in ViewController.m. .. code-block:: cpp UIAlertView * alert = [[UIAlertView alloc] initWithTitle:@"Hello!" message:@"Welcome to OpenCV" delegate:self cancelButtonTitle:@"Continue" otherButtonTitles:nil]; [alert show]; .. image:: images/view_did_load.png :alt: view did load :align: center .. container:: enumeratevisibleitemswithsquare * You are good to run the project. *Output* ========= .. image:: images/output.png :alt: output :align: center *Changes for XCode5+ and iOS8+* =============================== With the newer XCode and iOS versions you need to watch out for some specific details .. container:: enumerateattentionpoints * The ``*.m`` file in your project should be renamed to ``*.mm``. * You have to manually include AssetsLibrary.framework into your project, which is not done anymore by default.