OpenCV By Example
上QQ阅读APP看书,第一时间看更新

Creating a library

CMake allows you to create libraries, which are indeed used by the OpenCV build system. Factorizing the shared code among multiple applications is a common and useful practice in software development. In big applications or when the common code is shared in multiple applications, this practice is very useful.

In this case, we do not create a binary executable; instead, we create a compiled file that includes all the functions, classes, and so on, developed. We can then share this library file with the other applications without sharing our source code.

CMake includes the add_library function for this purpose:

# Create our hello library
add_library(Hello hello.cpp hello.h)

# Create our application that uses our new library
add_executable(executable main.cpp)

# Link our executable with the new library
target_link_libraries( executable Hello )

The lines starting with # add comments and are ignored by CMake.

The add_library(Hello hello.cpp hello.h) command defines our new library called, where Hello is the library name and hello.cpp, hello.h are the source files. We add the header file to allow IDEs such as Visual Studio to link to the header files.

This line will generate a shared file (So for OS X and Unix or .dll for Windows) or a static library (A for OS X and Unix or .dll for Windows), depending on our operating system or if it is a dynamic or static library.

target_link_libraries( executable Hello) is the function that links our executable to the desired library; in our case, it's the Hello library.