Add device layer
This commit is contained in:
parent
1f3ec9d621
commit
905bafd26d
|
@ -93,6 +93,8 @@ set(MYNTEYE_SRCS
|
||||||
${UVC_SRC}
|
${UVC_SRC}
|
||||||
src/internal/types.cc
|
src/internal/types.cc
|
||||||
src/public/types.cc
|
src/public/types.cc
|
||||||
|
src/device/context.cc
|
||||||
|
src/device/device.cc
|
||||||
)
|
)
|
||||||
|
|
||||||
set(MYNTEYE_LINKLIBS
|
set(MYNTEYE_LINKLIBS
|
||||||
|
|
|
@ -40,6 +40,14 @@ include(${PRO_DIR}/cmake/Common.cmake)
|
||||||
|
|
||||||
set(OUT_DIR "${CMAKE_CURRENT_SOURCE_DIR}/_output")
|
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
|
# samples above uvc layer
|
||||||
|
|
||||||
add_subdirectory(uvc)
|
add_subdirectory(uvc)
|
||||||
|
|
22
samples/device/CMakeLists.txt
Normal file
22
samples/device/CMakeLists.txt
Normal 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
13
samples/device/camera.cc
Normal 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
30
samples/glog_init.h
Normal 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
|
|
@ -10,13 +10,13 @@ include_directories(
|
||||||
${PRO_DIR}/src
|
${PRO_DIR}/src
|
||||||
)
|
)
|
||||||
|
|
||||||
## camera
|
## camera_u
|
||||||
|
|
||||||
add_executable(camera camera.cc)
|
add_executable(camera_u camera.cc)
|
||||||
target_link_libraries(camera mynteye ${OpenCV_LIBS})
|
target_link_libraries(camera_u mynteye ${OpenCV_LIBS})
|
||||||
|
|
||||||
if(OS_WIN)
|
if(OS_WIN)
|
||||||
target_compile_definitions(camera
|
target_compile_definitions(camera_u
|
||||||
PUBLIC GLOG_NO_ABBREVIATED_SEVERITIES
|
PUBLIC GLOG_NO_ABBREVIATED_SEVERITIES
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
|
@ -1,5 +1,3 @@
|
||||||
#include <glog/logging.h>
|
|
||||||
|
|
||||||
#include <opencv2/highgui/highgui.hpp>
|
#include <opencv2/highgui/highgui.hpp>
|
||||||
#include <opencv2/imgproc/imgproc.hpp>
|
#include <opencv2/imgproc/imgproc.hpp>
|
||||||
|
|
||||||
|
@ -14,28 +12,7 @@
|
||||||
#include "internal/types.h"
|
#include "internal/types.h"
|
||||||
#include "uvc/uvc.h"
|
#include "uvc/uvc.h"
|
||||||
|
|
||||||
struct glog_init {
|
#include "glog_init.h" // NOLINT
|
||||||
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();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
struct frame {
|
struct frame {
|
||||||
const void *data = nullptr;
|
const void *data = nullptr;
|
||||||
|
|
30
src/device/context.cc
Normal file
30
src/device/context.cc
Normal 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
36
src/device/context.h
Normal 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
22
src/device/device.cc
Normal 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
31
src/device/device.h
Normal 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
|
|
@ -1,4 +1,4 @@
|
||||||
#include "uvc.h" // NOLINT
|
#include "uvc/uvc.h" // NOLINT
|
||||||
|
|
||||||
#include <glog/logging.h>
|
#include <glog/logging.h>
|
||||||
#include <libuvc/libuvc.h>
|
#include <libuvc/libuvc.h>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
#include "uvc.h" // NOLINT
|
#include "uvc/uvc.h" // NOLINT
|
||||||
|
|
||||||
#include <dirent.h>
|
#include <dirent.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
@ -79,6 +79,7 @@ struct device {
|
||||||
std::string dev_name; // Device name (typically of the form /dev/video*)
|
std::string dev_name; // Device name (typically of the form /dev/video*)
|
||||||
int busnum, devnum, parent_devnum; // USB device bus number and device number
|
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 vid, pid, mi; // Vendor ID, product ID, and multiple interface index
|
||||||
int fd = -1; // File descriptor for this device
|
int fd = -1; // File descriptor for this device
|
||||||
|
|
||||||
|
@ -125,6 +126,10 @@ struct device {
|
||||||
if (!good)
|
if (!good)
|
||||||
LOG(FATAL) << "Failed to read busnum/devnum";
|
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;
|
std::string modalias;
|
||||||
if (!(std::ifstream(
|
if (!(std::ifstream(
|
||||||
"/sys/class/video4linux/" + name + "/device/modalias") >>
|
"/sys/class/video4linux/" + name + "/device/modalias") >>
|
||||||
|
@ -423,6 +428,10 @@ std::vector<std::shared_ptr<device>> query_devices(
|
||||||
return devices;
|
return devices;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string get_name(const device &device) {
|
||||||
|
return device.name;
|
||||||
|
}
|
||||||
|
|
||||||
int get_vendor_id(const device &device) {
|
int get_vendor_id(const device &device) {
|
||||||
return device.vid;
|
return device.vid;
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,6 +30,7 @@ std::vector<std::shared_ptr<device>> query_devices(
|
||||||
std::shared_ptr<context> context);
|
std::shared_ptr<context> context);
|
||||||
|
|
||||||
// Static device properties
|
// Static device properties
|
||||||
|
std::string get_name(const device &device);
|
||||||
int get_vendor_id(const device &device);
|
int get_vendor_id(const device &device);
|
||||||
int get_product_id(const device &device);
|
int get_product_id(const device &device);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user