Diffstat (limited to 'noncore/multimedia/camera/zcameraio.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r-- | noncore/multimedia/camera/zcameraio.cpp | 44 |
1 files changed, 39 insertions, 5 deletions
diff --git a/noncore/multimedia/camera/zcameraio.cpp b/noncore/multimedia/camera/zcameraio.cpp index b37ae8c..9af0c25 100644 --- a/noncore/multimedia/camera/zcameraio.cpp +++ b/noncore/multimedia/camera/zcameraio.cpp | |||
@@ -61,4 +61,5 @@ void ZCameraIO::init() | |||
61 | else | 61 | else |
62 | { | 62 | { |
63 | _timer = new QTime(); | ||
63 | setReadMode( STATUS ); | 64 | setReadMode( STATUS ); |
64 | } | 65 | } |
@@ -84,6 +85,16 @@ bool ZCameraIO::isOpen() const | |||
84 | bool ZCameraIO::isShutterPressed() | 85 | bool ZCameraIO::isShutterPressed() |
85 | { | 86 | { |
86 | return _status[0] == 'S'; | 87 | if ( _timer->elapsed() < 1000 ) //TODO: make this customizable? |
87 | clearShutterLatch(); | 88 | { |
89 | clearShutterLatch(); | ||
90 | return false; | ||
91 | } | ||
92 | if ( _status[0] == 'S' ) | ||
93 | { | ||
94 | _timer->restart(); | ||
95 | clearShutterLatch(); | ||
96 | return true; | ||
97 | } | ||
98 | else return false; | ||
88 | } | 99 | } |
89 | 100 | ||
@@ -125,4 +136,10 @@ bool ZCameraIO::setCaptureFrame( int width, int height, int zoom, bool rot ) | |||
125 | 136 | ||
126 | 137 | ||
138 | bool ZCameraIO::setZoom( int zoom ) | ||
139 | { | ||
140 | return setCaptureFrame( _width, _height, zoom*256, _rot ); | ||
141 | } | ||
142 | |||
143 | |||
127 | void ZCameraIO::setReadMode( int mode ) | 144 | void ZCameraIO::setReadMode( int mode ) |
128 | { | 145 | { |
@@ -130,6 +147,9 @@ void ZCameraIO::setReadMode( int mode ) | |||
130 | sprintf( b, "M=%d", mode ); | 147 | sprintf( b, "M=%d", mode ); |
131 | write( b, mode <= 9 ? 3 : 4 ); | 148 | write( b, mode <= 9 ? 3 : 4 ); |
132 | if ( mode & 1 ) // STATUS bit is set | 149 | if ( mode & STATUS ) // STATUS bit is set |
150 | { | ||
133 | read( _status, 4 ); | 151 | read( _status, 4 ); |
152 | if ( isShutterPressed() ) emit shutterClicked(); | ||
153 | } | ||
134 | } | 154 | } |
135 | 155 | ||
@@ -137,6 +157,5 @@ void ZCameraIO::setReadMode( int mode ) | |||
137 | void ZCameraIO::clearShutterLatch() | 157 | void ZCameraIO::clearShutterLatch() |
138 | { | 158 | { |
139 | char b = 'B'; | 159 | write( "B", 1 ); |
140 | write( &b, 1 ); | ||
141 | } | 160 | } |
142 | 161 | ||
@@ -213,4 +232,5 @@ bool ZCameraIO::snapshot( QImage* image ) | |||
213 | } | 232 | } |
214 | 233 | ||
234 | |||
215 | bool ZCameraIO::snapshot( unsigned char* buf ) | 235 | bool ZCameraIO::snapshot( unsigned char* buf ) |
216 | { | 236 | { |
@@ -229,2 +249,16 @@ bool ZCameraIO::snapshot( unsigned char* buf ) | |||
229 | } | 249 | } |
230 | 250 | ||
251 | |||
252 | void ZCameraIO::captureFrame( int w, int h, int zoom, QImage* image ) | ||
253 | { | ||
254 | int pw = _width; | ||
255 | int ph = _height; | ||
256 | if ( _rot ) | ||
257 | setCaptureFrame( h, w, zoom*256, true ); | ||
258 | else | ||
259 | setCaptureFrame( w, h, zoom*256, false ); | ||
260 | snapshot( image ); | ||
261 | setCaptureFrame( pw, ph, _zoom, _rot ); | ||
262 | } | ||
263 | |||
264 | |||