【OpenREALM学习笔记:7】自己编写的读取原作者数据集航向角的程序

11 篇文章 0 订阅

代码内容:

#include <iostream>
#include <exiv2/exiv2.hpp>
#include <boost/filesystem.hpp>

std::string FindXmpKey(Exiv2::XmpData &xmpData, const std::string &key) {
    if (xmpData.findKey(Exiv2::XmpKey(key)) != xmpData.end())
        return xmpData[key].toString();
    else
        return "";
}

void readFilenamesBoost(std::vector<std::string> &filenames, const std::string &folder) {
    boost::filesystem::path directory(folder);
    boost::filesystem::directory_iterator itr(directory), end_itr;
    std::string current_file = itr->path().string();

    for (; itr != end_itr; ++itr) {
        if (boost::filesystem::is_regular_file(itr->path())) {
            std::string filename = itr->path().filename().string();
            filenames.push_back(filename);
        }
    }
}

int main() {
    std::string folder = "/home/wanghui/Datasets/edm_big_overlap_50p/";
    std::vector<std::string> filenames;

    readFilenamesBoost(filenames, folder);
    std::sort(filenames.begin(), filenames.end());
    for (auto &filename: filenames) {
        auto image = Exiv2::ImageFactory::open(folder + filename);
        image->readMetadata();
        Exiv2::ExifData &exifData = image->exifData();
        Exiv2::XmpData &xmp_data = image->xmpData();
        std::cout << "File: " << filename << ", ";
        std::cout << "REALM.Heading: " << FindXmpKey(xmp_data, "Xmp.exif.REALM.Heading") << std::endl;
    }
}

CMakelists.txt

cmake_minimum_required(VERSION 3.28)
project(readexiv2)

set(CMAKE_CXX_STANDARD 17)

list(APPEND CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR})

find_package(Boost REQUIRED)

find_package(Exiv2 REQUIRED)

include_directories(${Exiv2_INCLUDE_DIRS})

add_executable(readexiv2 main.cpp)

target_link_libraries(readexiv2 ${Exiv2_LIBRARIES} -lboost_system -lboost_filesystem)

FindExiv2.cmake

# - Find the native exiv2 includes and library
#
# This module defines
#  EXIV2_INCLUDE_DIR, where to find png.h, etc.
#  EXIV2_LIBRARIES, the libraries to link against to use exiv2
#  EXIV2_FOUND, If false, do not try to use exiv2
# also defined, but not for general use are
#  EXIV2_LIBRARY, where to find the exiv2 library

#=============================================================================
# Copyright 2010 henrik andersson
#=============================================================================

include(LibFindMacros)

SET(EXIV2_FIND_REQUIRED ${Exiv2_FIND_REQUIRED})

libfind_pkg_check_modules(Exiv2 exiv2)

find_path(EXIV2_INCLUDE_DIR
        NAMES
        exiv2/image.hpp
        HINTS
        ${Exiv2_INCLUDEDIR}
        ${Exiv2_INCLUDE_DIRS}
        )
mark_as_advanced(EXIV2_INCLUDE_DIR)

set(EXIV2_NAMES ${EXIV2_NAMES} exiv2 libexiv2)
find_library(EXIV2_LIBRARY
        NAMES
        ${EXIV2_NAMES}
        HINTS
        ${Exiv2_LIBDIR}
        ${Exiv2_LIBRARY_DIRS}
        )
mark_as_advanced(EXIV2_LIBRARY)

if(WIN32)
  find_library(EXPAT_LIBRARY NAMES expat )
  find_library(ICONV_LIBRARY NAMES iconv )
  list(APPEND EXIV2_LIBRARY ${EXPAT_LIBRARY} ${ICONV_LIBRARY})
endif(WIN32)

if(Exiv2_VERSION VERSION_LESS Exiv2_FIND_VERSION)
  message(FATAL_ERROR "Exiv2 version check failed.  Version ${Exiv2_VERSION} was found, at least version ${Exiv2_FIND_VERSION} is required")
endif(Exiv2_VERSION VERSION_LESS Exiv2_FIND_VERSION)

include(FindPackageHandleStandardArgs)
find_package_handle_standard_args(EXIV2 DEFAULT_MSG EXIV2_LIBRARY EXIV2_INCLUDE_DIR)

IF(EXIV2_FOUND)
  SET(Exiv2_LIBRARIES ${EXIV2_LIBRARY})
  SET(Exiv2_INCLUDE_DIRS ${EXIV2_INCLUDE_DIR})
ENDIF(EXIV2_FOUND)

LibFindMacros.cmake

# Version 2.2
# Public Domain, originally written by Lasse Kärkkäinen <tronic>
# Maintained at https://github.com/Tronic/cmake-modules
# Please send your improvements as pull requests on Github.

# Find another package and make it a dependency of the current package.
# This also automatically forwards the "REQUIRED" argument.
# Usage: libfind_package(<prefix> <another package> [extra args to find_package])
macro (libfind_package PREFIX PKG)
    set(${PREFIX}_args ${PKG} ${ARGN})
    if (${PREFIX}_FIND_REQUIRED)
        set(${PREFIX}_args ${${PREFIX}_args} REQUIRED)
    endif()
    find_package(${${PREFIX}_args})
    set(${PREFIX}_DEPENDENCIES ${${PREFIX}_DEPENDENCIES};${PKG})
    unset(${PREFIX}_args)
endmacro()

# A simple wrapper to make pkg-config searches a bit easier.
# Works the same as CMake's internal pkg_check_modules but is always quiet.
macro (libfind_pkg_check_modules)
    find_package(PkgConfig QUIET)
    if (PKG_CONFIG_FOUND)
        pkg_check_modules(${ARGN} QUIET)
    endif()
endmacro()

# Avoid useless copy&pasta by doing what most simple libraries do anyway:
# pkg-config, find headers, find library.
# Usage: libfind_pkg_detect(<prefix> <pkg-config args> FIND_PATH <name> [other args] FIND_LIBRARY <name> [other args])
# E.g. libfind_pkg_detect(SDL2 sdl2 FIND_PATH SDL.h PATH_SUFFIXES SDL2 FIND_LIBRARY SDL2)
function (libfind_pkg_detect PREFIX)
    # Parse arguments
    set(argname pkgargs)
    foreach (i ${ARGN})
        if ("${i}" STREQUAL "FIND_PATH")
            set(argname pathargs)
        elseif ("${i}" STREQUAL "FIND_LIBRARY")
            set(argname libraryargs)
        else()
            set(${argname} ${${argname}} ${i})
        endif()
    endforeach()
    if (NOT pkgargs)
        message(FATAL_ERROR "libfind_pkg_detect requires at least a pkg_config package name to be passed.")
    endif()
    # Find library
    libfind_pkg_check_modules(${PREFIX}_PKGCONF ${pkgargs})
    if (pathargs)
        find_path(${PREFIX}_INCLUDE_DIR NAMES ${pathargs} HINTS ${${PREFIX}_PKGCONF_INCLUDE_DIRS})
    endif()
    if (libraryargs)
        find_library(${PREFIX}_LIBRARY NAMES ${libraryargs} HINTS ${${PREFIX}_PKGCONF_LIBRARY_DIRS})
    endif()
endfunction()

# Extracts a version #define from a version.h file, output stored to <PREFIX>_VERSION.
# Usage: libfind_version_header(Foobar foobar/version.h FOOBAR_VERSION_STR)
# Fourth argument "QUIET" may be used for silently testing different define names.
# This function does nothing if the version variable is already defined.
function (libfind_version_header PREFIX VERSION_H DEFINE_NAME)
    # Skip processing if we already have a version or if the include dir was not found
    if (${PREFIX}_VERSION OR NOT ${PREFIX}_INCLUDE_DIR)
        return()
    endif()
    set(quiet ${${PREFIX}_FIND_QUIETLY})
    # Process optional arguments
    foreach(arg ${ARGN})
        if (arg STREQUAL "QUIET")
            set(quiet TRUE)
        else()
            message(AUTHOR_WARNING "Unknown argument ${arg} to libfind_version_header ignored.")
        endif()
    endforeach()
    # Read the header and parse for version number
    set(filename "${${PREFIX}_INCLUDE_DIR}/${VERSION_H}")
    if (NOT EXISTS ${filename})
        if (NOT quiet)
            message(AUTHOR_WARNING "Unable to find ${${PREFIX}_INCLUDE_DIR}/${VERSION_H}")
        endif()
        return()
    endif()
    file(READ "${filename}" header)
    string(REGEX REPLACE ".*#[ \t]*define[ \t]*${DEFINE_NAME}[ \t]*\"([^\n]*)\".*" "\\1" match "${header}")
    # No regex match?
    if (match STREQUAL header)
        if (NOT quiet)
            message(AUTHOR_WARNING "Unable to find \#define ${DEFINE_NAME} \"<version>\" from ${${PREFIX}_INCLUDE_DIR}/${VERSION_H}")
        endif()
        return()
    endif()
    # Export the version string
    set(${PREFIX}_VERSION "${match}" PARENT_SCOPE)
endfunction()

# Do the final processing once the paths have been detected.
# If include dirs are needed, ${PREFIX}_PROCESS_INCLUDES should be set to contain
# all the variables, each of which contain one include directory.
# Ditto for ${PREFIX}_PROCESS_LIBS and library files.
# Will set ${PREFIX}_FOUND, ${PREFIX}_INCLUDE_DIRS and ${PREFIX}_LIBRARIES.
# Also handles errors in case library detection was required, etc.
function (libfind_process PREFIX)
    # Skip processing if already processed during this configuration run
    if (${PREFIX}_FOUND)
        return()
    endif()

    set(found TRUE)  # Start with the assumption that the package was found

    # Did we find any files? Did we miss includes? These are for formatting better error messages.
    set(some_files FALSE)
    set(missing_headers FALSE)

    # Shorthands for some variables that we need often
    set(quiet ${${PREFIX}_FIND_QUIETLY})
    set(required ${${PREFIX}_FIND_REQUIRED})
    set(exactver ${${PREFIX}_FIND_VERSION_EXACT})
    set(findver "${${PREFIX}_FIND_VERSION}")
    set(version "${${PREFIX}_VERSION}")

    # Lists of config option names (all, includes, libs)
    unset(configopts)
    set(includeopts ${${PREFIX}_PROCESS_INCLUDES})
    set(libraryopts ${${PREFIX}_PROCESS_LIBS})

    # Process deps to add to
    foreach (i ${PREFIX} ${${PREFIX}_DEPENDENCIES})
        if (DEFINED ${i}_INCLUDE_OPTS OR DEFINED ${i}_LIBRARY_OPTS)
            # The package seems to export option lists that we can use, woohoo!
            list(APPEND includeopts ${${i}_INCLUDE_OPTS})
            list(APPEND libraryopts ${${i}_LIBRARY_OPTS})
        else()
            # If plural forms don't exist or they equal singular forms
            if ((NOT DEFINED ${i}_INCLUDE_DIRS AND NOT DEFINED ${i}_LIBRARIES) OR
            ({i}_INCLUDE_DIR STREQUAL ${i}_INCLUDE_DIRS AND ${i}_LIBRARY STREQUAL ${i}_LIBRARIES))
                # Singular forms can be used
                if (DEFINED ${i}_INCLUDE_DIR)
                    list(APPEND includeopts ${i}_INCLUDE_DIR)
                endif()
                if (DEFINED ${i}_LIBRARY)
                    list(APPEND libraryopts ${i}_LIBRARY)
                endif()
            else()
                # Oh no, we don't know the option names
                message(FATAL_ERROR "We couldn't determine config variable names for ${i} includes and libs. Aieeh!")
            endif()
        endif()
    endforeach()

    if (includeopts)
        list(REMOVE_DUPLICATES includeopts)
    endif()

    if (libraryopts)
        list(REMOVE_DUPLICATES libraryopts)
    endif()

    string(REGEX REPLACE ".*[ ;]([^ ;]*(_INCLUDE_DIRS|_LIBRARIES))" "\\1" tmp "${includeopts} ${libraryopts}")
    if (NOT tmp STREQUAL "${includeopts} ${libraryopts}")
        message(AUTHOR_WARNING "Plural form ${tmp} found in config options of ${PREFIX}. This works as before but is now deprecated. Please only use singular forms INCLUDE_DIR and LIBRARY, and update your find scripts for LibFindMacros > 2.0 automatic dependency system (most often you can simply remove the PROCESS variables entirely).")
    endif()

    # Include/library names separated by spaces (notice: not CMake lists)
    unset(includes)
    unset(libs)

    # Process all includes and set found false if any are missing
    foreach (i ${includeopts})
        list(APPEND configopts ${i})
        if (NOT "${${i}}" STREQUAL "${i}-NOTFOUND")
            list(APPEND includes "${${i}}")
        else()
            set(found FALSE)
            set(missing_headers TRUE)
        endif()
    endforeach()

    # Process all libraries and set found false if any are missing
    foreach (i ${libraryopts})
        list(APPEND configopts ${i})
        if (NOT "${${i}}" STREQUAL "${i}-NOTFOUND")
            list(APPEND libs "${${i}}")
        else()
            set (found FALSE)
        endif()
    endforeach()

    # Version checks
    if (found AND findver)
        if (NOT version)
            message(WARNING "The find module for ${PREFIX} does not provide version information, so we'll just assume that it is OK. Please fix the module or remove package version requirements to get rid of this warning.")
        elseif (version VERSION_LESS findver OR (exactver AND NOT version VERSION_EQUAL findver))
            set(found FALSE)
            set(version_unsuitable TRUE)
        endif()
    endif()

    # If all-OK, hide all config options, export variables, print status and exit
    if (found)
        foreach (i ${configopts})
            mark_as_advanced(${i})
        endforeach()
        if (NOT quiet)
            message(STATUS "Found ${PREFIX} ${${PREFIX}_VERSION}")
            if (LIBFIND_DEBUG)
                message(STATUS "  ${PREFIX}_DEPENDENCIES=${${PREFIX}_DEPENDENCIES}")
                message(STATUS "  ${PREFIX}_INCLUDE_OPTS=${includeopts}")
                message(STATUS "  ${PREFIX}_INCLUDE_DIRS=${includes}")
                message(STATUS "  ${PREFIX}_LIBRARY_OPTS=${libraryopts}")
                message(STATUS "  ${PREFIX}_LIBRARIES=${libs}")
            endif()
            set (${PREFIX}_INCLUDE_OPTS ${includeopts} PARENT_SCOPE)
            set (${PREFIX}_LIBRARY_OPTS ${libraryopts} PARENT_SCOPE)
            set (${PREFIX}_INCLUDE_DIRS ${includes} PARENT_SCOPE)
            set (${PREFIX}_LIBRARIES ${libs} PARENT_SCOPE)
            set (${PREFIX}_FOUND TRUE PARENT_SCOPE)
        endif()
        return()
    endif()

    # Format messages for debug info and the type of error
    set(vars "Relevant CMake configuration variables:\n")
    foreach (i ${configopts})
        mark_as_advanced(CLEAR ${i})
        set(val ${${i}})
        if ("${val}" STREQUAL "${i}-NOTFOUND")
            set (val "<not found>")
        elseif (val AND NOT EXISTS ${val})
            set (val "${val}  (does not exist)")
        else()
            set(some_files TRUE)
        endif()
        set(vars "${vars}  ${i}=${val}\n")
    endforeach()
    set(vars "${vars}You may use CMake GUI, cmake -D or ccmake to modify the values. Delete CMakeCache.txt to discard all values and force full re-detection if necessary.\n")
    if (version_unsuitable)
        set(msg "${PREFIX} ${${PREFIX}_VERSION} was found but")
        if (exactver)
            set(msg "${msg} only version ${findver} is acceptable.")
        else()
            set(msg "${msg} version ${findver} is the minimum requirement.")
        endif()
    else()
        if (missing_headers)
            set(msg "We could not find development headers for ${PREFIX}. Do you have the necessary dev package installed?")
        elseif (some_files)
            set(msg "We only found some files of ${PREFIX}, not all of them. Perhaps your installation is incomplete or maybe we just didn't look in the right place?")
            if(findver)
                set(msg "${msg} This could also be caused by incompatible version (if it helps, at least ${PREFIX} ${findver} should work).")
            endif()
        else()
            set(msg "We were unable to find package ${PREFIX}.")
        endif()
    endif()

    # Fatal error out if REQUIRED
    if (required)
        set(msg "REQUIRED PACKAGE NOT FOUND\n${msg} This package is REQUIRED and you need to install it or adjust CMake configuration in order to continue building ${CMAKE_PROJECT_NAME}.")
        message(FATAL_ERROR "${msg}\n${vars}")
    endif()
    # Otherwise just print a nasty warning
    if (NOT quiet)
        message(WARNING "WARNING: MISSING PACKAGE\n${msg} This package is NOT REQUIRED and you may ignore this warning but by doing so you may miss some functionality of ${CMAKE_PROJECT_NAME}. \n${vars}")
    endif()
endfunction()

运行结果

/home/XXXX/Code/readexiv2/cmake-build-debug/readexiv2
File: img_0038.jpg, REALM.Heading: 346.480000
File: img_0039.jpg, REALM.Heading: 347.490000
File: img_0040.jpg, REALM.Heading: 347.850000
File: img_0041.jpg, REALM.Heading: 347.860000
File: img_0042.jpg, REALM.Heading: 347.400000
File: img_0043.jpg, REALM.Heading: 347.420000
File: img_0044.jpg, REALM.Heading: 347.420000
File: img_0045.jpg, REALM.Heading: 347.940000
File: img_0046.jpg, REALM.Heading: 348.560000
File: img_0047.jpg, REALM.Heading: 349.140000
File: img_0048.jpg, REALM.Heading: 349.140000
File: img_0049.jpg, REALM.Heading: 349.840000
File: img_0050.jpg, REALM.Heading: 351.180000
File: img_0051.jpg, REALM.Heading: 351.180000
File: img_0052.jpg, REALM.Heading: 351.340000
File: img_0053.jpg, REALM.Heading: 351.350000
File: img_0054.jpg, REALM.Heading: 351.160000
File: img_0055.jpg, REALM.Heading: 350.940000
File: img_0056.jpg, REALM.Heading: 349.870000
File: img_0057.jpg, REALM.Heading: 349.330000
File: img_0058.jpg, REALM.Heading: 348.770000
......
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值