boost::asio 读自 /dev/input/event0
boost::asio read from /dev/input/event0
我希望使用 boost::asio 从 12 位数字键盘读取。我目前可以在没有提升的情况下这样做:
fd = open ("/dev/input/event0", 0_NONBLOCK);
read (fd, &ev, sizeof ev);
你知道我如何用 boost::asio 做到这一点吗?我正在使用 Linux 和 C++。这post and this post很有用。我不会使用串行端口 port (io, "/dev/usb/hiddev0") 因为它不是串行的,对吗?
谢谢。
在我的系统上,event2
代表鼠标,下面这个简单的 readloop
程序非常有用。
运行 作为 root:
#include <boost/asio.hpp>
#include <boost/asio/posix/stream_descriptor.hpp>
#include <boost/bind.hpp>
#include <iostream> // for debug output
#include <iomanip>
#include <linux/input.h> // for input_event
#include <boost/range/adaptor/sliced.hpp>
#include <boost/date_time/posix_time/posix_time.hpp>
using namespace boost::asio;
struct input {
using error_code = boost::system::error_code;
using sliced = boost::adaptors::sliced;
input(const char* devspec) : svc(), sd(svc, open(devspec, O_RDONLY)) {
readloop(); // post work
}
void run() {
svc.run();
}
private:
io_service svc;
posix::stream_descriptor sd;
std::vector<input_event> events;
void handle_input(error_code ec, size_t bytes_transferred) {
if (!ec) {
auto const n = bytes_transferred / sizeof(input_event);
for (auto& ev : events | sliced(0,n)) {
using namespace boost::posix_time;
ptime ts({1970,1,1}, seconds(ev.time.tv_sec) + microsec(ev.time.tv_usec));
std::cout << std::dec << ts.time_of_day() << "\t" << std::hex
<< std::hex << ev.type << " " << ev.code << " " << ev.value << "\n";
}
std::cout << "\n";
readloop();
} else {
std::cerr << ec.message() << "\n";
}
}
void readloop() {
events.resize(32);
sd.async_read_some(buffer(events), boost::bind(&input::handle_input, this, placeholders::error, placeholders::bytes_transferred));
}
};
int main()
{
input monitor("/dev/input/event2");
monitor.run();
}
典型输出:
22:33:09.705346 2 0 ffffffff
22:33:09.705346 2 1 1
22:33:09.705346 0 0 0
22:33:09.713412 2 0 ffffffff
22:33:09.713412 2 1 1
22:33:09.713412 0 0 0
22:33:09.721308 2 0 ffffffff
22:33:09.721308 0 0 0
22:33:09.729328 2 0 ffffffff
22:33:09.729328 0 0 0
22:33:09.737346 2 1 1
22:33:09.737346 0 0 0
22:33:09.745328 2 0 ffffffff
22:33:09.745328 2 1 1
22:33:09.745328 0 0 0
22:33:11.897301 4 4 90001
22:33:11.897301 1 110 1
22:33:11.897301 0 0 0
22:33:12.065294 4 4 90001
22:33:12.065294 1 110 0
22:33:12.065294 0 0 0
我希望使用 boost::asio 从 12 位数字键盘读取。我目前可以在没有提升的情况下这样做:
fd = open ("/dev/input/event0", 0_NONBLOCK);
read (fd, &ev, sizeof ev);
你知道我如何用 boost::asio 做到这一点吗?我正在使用 Linux 和 C++。这post and this post很有用。我不会使用串行端口 port (io, "/dev/usb/hiddev0") 因为它不是串行的,对吗?
谢谢。
在我的系统上,event2
代表鼠标,下面这个简单的 readloop
程序非常有用。
运行 作为 root:
#include <boost/asio.hpp>
#include <boost/asio/posix/stream_descriptor.hpp>
#include <boost/bind.hpp>
#include <iostream> // for debug output
#include <iomanip>
#include <linux/input.h> // for input_event
#include <boost/range/adaptor/sliced.hpp>
#include <boost/date_time/posix_time/posix_time.hpp>
using namespace boost::asio;
struct input {
using error_code = boost::system::error_code;
using sliced = boost::adaptors::sliced;
input(const char* devspec) : svc(), sd(svc, open(devspec, O_RDONLY)) {
readloop(); // post work
}
void run() {
svc.run();
}
private:
io_service svc;
posix::stream_descriptor sd;
std::vector<input_event> events;
void handle_input(error_code ec, size_t bytes_transferred) {
if (!ec) {
auto const n = bytes_transferred / sizeof(input_event);
for (auto& ev : events | sliced(0,n)) {
using namespace boost::posix_time;
ptime ts({1970,1,1}, seconds(ev.time.tv_sec) + microsec(ev.time.tv_usec));
std::cout << std::dec << ts.time_of_day() << "\t" << std::hex
<< std::hex << ev.type << " " << ev.code << " " << ev.value << "\n";
}
std::cout << "\n";
readloop();
} else {
std::cerr << ec.message() << "\n";
}
}
void readloop() {
events.resize(32);
sd.async_read_some(buffer(events), boost::bind(&input::handle_input, this, placeholders::error, placeholders::bytes_transferred));
}
};
int main()
{
input monitor("/dev/input/event2");
monitor.run();
}
典型输出:
22:33:09.705346 2 0 ffffffff
22:33:09.705346 2 1 1
22:33:09.705346 0 0 0
22:33:09.713412 2 0 ffffffff
22:33:09.713412 2 1 1
22:33:09.713412 0 0 0
22:33:09.721308 2 0 ffffffff
22:33:09.721308 0 0 0
22:33:09.729328 2 0 ffffffff
22:33:09.729328 0 0 0
22:33:09.737346 2 1 1
22:33:09.737346 0 0 0
22:33:09.745328 2 0 ffffffff
22:33:09.745328 2 1 1
22:33:09.745328 0 0 0
22:33:11.897301 4 4 90001
22:33:11.897301 1 110 1
22:33:11.897301 0 0 0
22:33:12.065294 4 4 90001
22:33:12.065294 1 110 0
22:33:12.065294 0 0 0