2015-01-07 5 views
3

나는 boost :: asio를 사용하여 12 자리 키패드를 읽으려고한다. 현재 다음과 같이 부스트없이이 작업을 수행 할 수 있습니다.boost :: asio read from/dev/input/event0

fd = open ("/dev/input/event0", 0_NONBLOCK); 
read (fd, &ev, sizeof ev); 

내가 boost :: asio로 어떻게 할 수 있는지 알고 있니? Linux 및 C++을 사용하고 있습니다. 이 post 및이 post이 유용합니다. serial port port (io, "/ dev/usb/hiddev0")를 사용하지 않을 것입니다. 직렬 포트가 아니기 때문입니다.

감사합니다.

+0

는 다음 ASIO에서 그것을 사용하는 내가 – xinthose

+2

'Boost.Asio' 생각 루트로

실행 최신 C++ 인터페이스를 제공하지만 구현시 일반 C (또는 OS) 기능을 사용합니다. 먼저, 위의'read'가 왜 작동하지 않는지 이해할 가치가 있습니다. 어떤 행동을 관찰합니까? –

+1

관련성이 높음 : 원시 장치 대신 라이브러리를 사용하는 것이 좋습니다. http://stackoverflow.com/a/25559167/85371 – sehe

답변

4

내 시스템에서 event2은 마우스를 나타내며 다음과 같은 간단한 readloop 프로그램은 매력처럼 작동합니다.

#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 
+1

당신이 그것을 시도 할 때까지 아마 "해결책"으로 받아 들여서는 안된다. :) – sehe

+1

친숙한 μs 타임 스탬프와 이벤트 배치를 출력하면서 이벤트를 실제로 디코딩하도록 업데이트했다. _ (Asio가 투명하게 POD 구조체의 벡터를 쓰기 버퍼로 사용하는 방법에 대한 포스터 - 자식입니다.) _ – sehe

+1

가능하게 date_time. (당신은 아마도 [첫 번째 버전] (http://stackoverflow.com/revisions/27827955/1)과 대조 할 수 있습니다. – sehe