Add device layer

This commit is contained in:
John Zhao 2018-04-04 10:50:27 +08:00
parent 1f3ec9d621
commit 905bafd26d
14 changed files with 211 additions and 30 deletions

View File

@ -93,6 +93,8 @@ set(MYNTEYE_SRCS
${UVC_SRC}
src/internal/types.cc
src/public/types.cc
src/device/context.cc
src/device/device.cc
)
set(MYNTEYE_LINKLIBS

View File

@ -40,6 +40,14 @@ include(${PRO_DIR}/cmake/Common.cmake)
set(OUT_DIR "${CMAKE_CURRENT_SOURCE_DIR}/_output")
include_directories(
${CMAKE_CURRENT_SOURCE_DIR}
)
# samples above device layer
add_subdirectory(device)
# samples above uvc layer
add_subdirectory(uvc)

View File

@ -0,0 +1,22 @@
get_filename_component(DIR_NAME ${CMAKE_CURRENT_LIST_DIR} NAME)
set_outdir(
"${OUT_DIR}/lib/${DIR_NAME}"
"${OUT_DIR}/lib/${DIR_NAME}"
"${OUT_DIR}/bin/${DIR_NAME}"
)
include_directories(
${PRO_DIR}/src
)
## camera_d
add_executable(camera_d camera.cc)
target_link_libraries(camera_d mynteye ${OpenCV_LIBS})
if(OS_WIN)
target_compile_definitions(camera_d
PUBLIC GLOG_NO_ABBREVIATED_SEVERITIES
)
endif()

13
samples/device/camera.cc Normal file
View File

@ -0,0 +1,13 @@
#include "glog_init.h" // NOLINT
#include "device/context.h"
MYNTEYE_USE_NAMESPACE
int main(int argc, char *argv[]) {
glog_init _(argc, argv);
Context context;
return 0;
}

30
samples/glog_init.h Normal file
View File

@ -0,0 +1,30 @@
#ifndef MYNTEYE_GLOG_INIT_H_ // NOLINT
#define MYNTEYE_GLOG_INIT_H_
#pragma once
#include <glog/logging.h>
struct glog_init {
glog_init(int /*argc*/, char *argv[]) {
// FLAGS_logtostderr = true;
FLAGS_alsologtostderr = true;
FLAGS_colorlogtostderr = true;
FLAGS_log_dir = ".";
FLAGS_max_log_size = 1024;
FLAGS_stop_logging_if_full_disk = true;
FLAGS_v = 2;
google::InitGoogleLogging(argv[0]);
VLOG(2) << __func__;
}
~glog_init() {
VLOG(2) << __func__;
google::ShutdownGoogleLogging();
}
};
#endif // MYNTEYE_GLOG_INIT_H_ NOLINT

View File

@ -10,13 +10,13 @@ include_directories(
${PRO_DIR}/src
)
## camera
## camera_u
add_executable(camera camera.cc)
target_link_libraries(camera mynteye ${OpenCV_LIBS})
add_executable(camera_u camera.cc)
target_link_libraries(camera_u mynteye ${OpenCV_LIBS})
if(OS_WIN)
target_compile_definitions(camera
target_compile_definitions(camera_u
PUBLIC GLOG_NO_ABBREVIATED_SEVERITIES
)
endif()

View File

@ -1,5 +1,3 @@
#include <glog/logging.h>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
@ -14,28 +12,7 @@
#include "internal/types.h"
#include "uvc/uvc.h"
struct glog_init {
glog_init(int /*argc*/, char *argv[]) {
// FLAGS_logtostderr = true;
FLAGS_alsologtostderr = true;
FLAGS_colorlogtostderr = true;
FLAGS_log_dir = ".";
FLAGS_max_log_size = 1024;
FLAGS_stop_logging_if_full_disk = true;
// FLAGS_v = 2;
google::InitGoogleLogging(argv[0]);
VLOG(2) << __func__;
}
~glog_init() {
VLOG(2) << __func__;
google::ShutdownGoogleLogging();
}
};
#include "glog_init.h" // NOLINT
struct frame {
const void *data = nullptr;

30
src/device/context.cc Normal file
View File

@ -0,0 +1,30 @@
#include "device/context.h"
#include <glog/logging.h>
#include "device/device.h"
#include "uvc/uvc.h"
MYNTEYE_BEGIN_NAMESPACE
Context::Context() : context_(uvc::create_context()) {
VLOG(2) << __func__;
for (auto &&device : uvc::query_devices(context_)) {
auto name = uvc::get_name(*device);
auto vid = uvc::get_vendor_id(*device);
auto pid = uvc::get_product_id(*device);
// auto video_name = uvc::get_video_name(*device);
LOG(INFO) << "name: " << name << ", vid: 0x" << std::hex << vid
<< ", pid: 0x" << std::hex << pid;
if (vid == MYNTEYE_VID) {
devices_.push_back(Device::Create(name, device));
}
}
}
Context::~Context() {
VLOG(2) << __func__;
}
MYNTEYE_END_NAMESPACE

36
src/device/context.h Normal file
View File

@ -0,0 +1,36 @@
#ifndef MYNTEYE_CONTEXT_H_ // NOLINT
#define MYNTEYE_CONTEXT_H_
#pragma once
#include <memory>
#include <vector>
#include "mynteye/mynteye.h"
MYNTEYE_BEGIN_NAMESPACE
namespace uvc {
struct context;
} // namespace uvc
class Device;
class Context {
public:
Context();
~Context();
std::vector<std::shared_ptr<Device>> devices() const {
return devices_;
}
private:
std::shared_ptr<uvc::context> context_;
std::vector<std::shared_ptr<Device>> devices_;
};
MYNTEYE_END_NAMESPACE
#endif // MYNTEYE_CONTEXT_H_ NOLINT

22
src/device/device.cc Normal file
View File

@ -0,0 +1,22 @@
#include "device/device.h"
#include <glog/logging.h>
#include "uvc/uvc.h"
MYNTEYE_BEGIN_NAMESPACE
Device::Device() {
VLOG(2) << __func__;
}
Device::~Device() {
VLOG(2) << __func__;
}
std::shared_ptr<Device> Device::Create(
const std::string &name, std::shared_ptr<uvc::device> device) {
return nullptr;
}
MYNTEYE_END_NAMESPACE

31
src/device/device.h Normal file
View File

@ -0,0 +1,31 @@
#ifndef MYNTEYE_DEVICE_H_ // NOLINT
#define MYNTEYE_DEVICE_H_
#pragma once
#include <memory>
#include <string>
#include "mynteye/mynteye.h"
MYNTEYE_BEGIN_NAMESPACE
namespace uvc {
struct device;
} // namespace uvc
class Device {
public:
Device();
virtual ~Device();
static std::shared_ptr<Device> Create(
const std::string &name, std::shared_ptr<uvc::device> device);
private:
};
MYNTEYE_END_NAMESPACE
#endif // MYNTEYE_DEVICE_H_ NOLINT

View File

@ -1,4 +1,4 @@
#include "uvc.h" // NOLINT
#include "uvc/uvc.h" // NOLINT
#include <glog/logging.h>
#include <libuvc/libuvc.h>

View File

@ -1,4 +1,4 @@
#include "uvc.h" // NOLINT
#include "uvc/uvc.h" // NOLINT
#include <dirent.h>
#include <errno.h>
@ -79,6 +79,7 @@ struct device {
std::string dev_name; // Device name (typically of the form /dev/video*)
int busnum, devnum, parent_devnum; // USB device bus number and device number
std::string name; // Device description name
int vid, pid, mi; // Vendor ID, product ID, and multiple interface index
int fd = -1; // File descriptor for this device
@ -125,6 +126,10 @@ struct device {
if (!good)
LOG(FATAL) << "Failed to read busnum/devnum";
if (!(std::ifstream("/sys/class/video4linux/" + name + "/name") >>
this->name))
LOG(FATAL) << "Failed to read name";
std::string modalias;
if (!(std::ifstream(
"/sys/class/video4linux/" + name + "/device/modalias") >>
@ -423,6 +428,10 @@ std::vector<std::shared_ptr<device>> query_devices(
return devices;
}
std::string get_name(const device &device) {
return device.name;
}
int get_vendor_id(const device &device) {
return device.vid;
}

View File

@ -30,6 +30,7 @@ std::vector<std::shared_ptr<device>> query_devices(
std::shared_ptr<context> context);
// Static device properties
std::string get_name(const device &device);
int get_vendor_id(const device &device);
int get_product_id(const device &device);