summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/multimedia/camera/mainwindow.cpp11
-rw-r--r--noncore/multimedia/camera/mainwindow.h6
-rw-r--r--noncore/multimedia/camera/zcameraio.cpp35
-rw-r--r--noncore/multimedia/camera/zcameraio.h3
4 files changed, 49 insertions, 6 deletions
diff --git a/noncore/multimedia/camera/mainwindow.cpp b/noncore/multimedia/camera/mainwindow.cpp
index 6431dfa..2cca9f9 100644
--- a/noncore/multimedia/camera/mainwindow.cpp
+++ b/noncore/multimedia/camera/mainwindow.cpp
@@ -15,4 +15,5 @@
#include "mainwindow.h"
+#include "zcameraio.h"
#include <qvbox.h>
@@ -27,5 +28,5 @@ CameraMainWindow::CameraMainWindow( QWidget * parent, const char * name, WFlags
{
QVBox* v = new QVBox( this );
- QLabel* l = new QLabel( v );
+ l = new QLabel( v );
l->setFixedSize( QSize( 240, 160 ) );
QPushButton* p = new QPushButton( "Snapshot", v );
@@ -46,5 +47,11 @@ CameraMainWindow::~CameraMainWindow()
void CameraMainWindow::clickedSnapShot()
{
- qDebug( "Hello!" );
+ QImage i;
+ QPixmap p;
+ if ( ZCameraIO::instance()->snapshot( &i ) )
+ {
+ p.convertFromImage( i );
+ l->setPixmap( p );
+ }
}
diff --git a/noncore/multimedia/camera/mainwindow.h b/noncore/multimedia/camera/mainwindow.h
index a349652..521107b 100644
--- a/noncore/multimedia/camera/mainwindow.h
+++ b/noncore/multimedia/camera/mainwindow.h
@@ -19,8 +19,7 @@
#include <qmainwindow.h>
-class Wellenreiter;
-class WellenreiterConfigWindow;
class QIconSet;
class QToolButton;
+class QLabel;
class CameraMainWindow: public QMainWindow
@@ -36,4 +35,7 @@ class CameraMainWindow: public QMainWindow
public slots:
void clickedSnapShot();
+
+ private:
+ QLabel* l;
};
diff --git a/noncore/multimedia/camera/zcameraio.cpp b/noncore/multimedia/camera/zcameraio.cpp
index aa6cbe3..e74136f 100644
--- a/noncore/multimedia/camera/zcameraio.cpp
+++ b/noncore/multimedia/camera/zcameraio.cpp
@@ -27,4 +27,6 @@
#include <opie2/odebug.h>
+ZCameraIO* ZCameraIO::_instance = 0;
+
ZCameraIO::ZCameraIO()
{
@@ -33,4 +35,5 @@ ZCameraIO::ZCameraIO()
oerr << "Can't open camera driver: " << strerror(errno) << oendl;
+ ZCameraIO::_instance = this;
};
@@ -43,6 +46,8 @@ ZCameraIO::~ZCameraIO()
-bool ZCameraIO::snapshot( QImage* img )
+bool ZCameraIO::snapshot( QImage* image )
{
+ /*
+
char buf[76800];
@@ -54,3 +59,31 @@ bool ZCameraIO::snapshot( QImage* img )
return result == sizeof buf;
+
+ */
+
+ uchar buf[76800];
+ uchar* bp = buf;
+ uchar* p;
+
+
+ int fd = open( "/tmp/cam", O_RDONLY );
+ if ( read( fd, buf, sizeof buf ) != sizeof buf )
+ qDebug( "WARNING: couldn't read image!" );
+
+ image->create( 240, 160, 16 );
+ for ( int i = 0; i < 160; ++i )
+ {
+ p = image->scanLine( i );
+ for ( int j = 0; j < 240; j++ )
+ {
+ *p = *bp;
+ p++;
+ bp++;
+ *p = *bp;
+ p++;
+ bp++;
+ }
+ }
+
+ return true;
}
diff --git a/noncore/multimedia/camera/zcameraio.h b/noncore/multimedia/camera/zcameraio.h
index 817d3b4..1690aa6 100644
--- a/noncore/multimedia/camera/zcameraio.h
+++ b/noncore/multimedia/camera/zcameraio.h
@@ -26,9 +26,10 @@ class ZCameraIO
bool isOpen() const { return _driver != -1; };
-
bool snapshot( QImage* );
+ static ZCameraIO* instance() { return _instance; };
private:
int _driver;
+ static ZCameraIO* _instance;
};