-rw-r--r-- | core/applets/screenshotapplet/screenshot.cpp | 408 |
1 files changed, 196 insertions, 212 deletions
diff --git a/core/applets/screenshotapplet/screenshot.cpp b/core/applets/screenshotapplet/screenshot.cpp index fab4044..b987392 100644 --- a/core/applets/screenshotapplet/screenshot.cpp +++ b/core/applets/screenshotapplet/screenshot.cpp @@ -14,43 +14,27 @@ #include "screenshot.h" #include "inputDialog.h" -#include <qapplication.h> #include <stdlib.h> #include <sys/socket.h> #include <netinet/in.h> #include <netdb.h> #include <unistd.h> -#include <qpe/resource.h> #include <qpe/qpeapplication.h> -#include <qpe/timestring.h> -#include <qpe/resource.h> -#include <qpe/config.h> #include <qpe/applnk.h> -#include <qpe/config.h> #include <qlineedit.h> #include <qdir.h> -#include <qfileinfo.h> #include <qlabel.h> #include <qpushbutton.h> #include <qpainter.h> -#include <qcombobox.h> #include <qspinbox.h> -#include <qslider.h> #include <qlayout.h> -#include <qframe.h> -#include <qpixmap.h> -#include <qregexp.h> -#include <qstring.h> -#include <qfile.h> -#include <qtimer.h> -#include <qfile.h> -#include <qdatastream.h> #include <qcheckbox.h> #include <qmessagebox.h> +#include <qimage.h> static char * snapshot_xpm[] = { "16 16 10 1", @@ -85,253 +69,253 @@ static const char *SCAP_hostname = "www.handhelds.org"; static const int SCAP_port = 80; ScreenshotControl::ScreenshotControl( QWidget *parent, const char *name ) - : QFrame( parent, name, WDestructiveClose | WStyle_StaysOnTop | WType_Popup ) + : QFrame( parent, name, WDestructiveClose | WStyle_StaysOnTop | WType_Popup ) { - setFrameStyle( QFrame::PopupPanel | QFrame::Raised ); - QVBoxLayout *vbox = new QVBoxLayout ( this, 5, 3 ); - QHBoxLayout *hbox; + setFrameStyle( QFrame::PopupPanel | QFrame::Raised ); + QVBoxLayout *vbox = new QVBoxLayout ( this, 5, 3 ); + QHBoxLayout *hbox; - hbox = new QHBoxLayout ( vbox ); + hbox = new QHBoxLayout ( vbox ); - QLabel *l = new QLabel ( tr( "Delay" ), this ); - hbox-> addWidget ( l ); + QLabel *l = new QLabel ( tr( "Delay" ), this ); + hbox-> addWidget ( l ); - delaySpin = new QSpinBox( 0, 60, 1, this, "Spinner" ); - delaySpin-> setButtonSymbols ( QSpinBox::PlusMinus ); - delaySpin-> setSuffix ( tr( "sec" )); - delaySpin-> setFocusPolicy( QWidget::NoFocus ); - delaySpin-> setValue ( 1 ); - hbox-> addWidget ( delaySpin ); + delaySpin = new QSpinBox( 0, 60, 1, this, "Spinner" ); + delaySpin-> setButtonSymbols ( QSpinBox::PlusMinus ); + delaySpin-> setSuffix ( tr( "sec" )); + delaySpin-> setFocusPolicy( QWidget::NoFocus ); + delaySpin-> setValue ( 1 ); + hbox-> addWidget ( delaySpin ); - saveNamedCheck = new QCheckBox ( tr( "Save named" ), this); - saveNamedCheck-> setFocusPolicy ( QWidget::NoFocus ); - vbox->addWidget( saveNamedCheck); + saveNamedCheck = new QCheckBox ( tr( "Save named" ), this); + saveNamedCheck-> setFocusPolicy ( QWidget::NoFocus ); + vbox->addWidget( saveNamedCheck); - vbox-> addSpacing ( 3 ); + vbox-> addSpacing ( 3 ); - l = new QLabel ( tr( "Save screenshot as..." ), this ); - vbox-> addWidget ( l, AlignCenter ); + l = new QLabel ( tr( "Save screenshot as..." ), this ); + vbox-> addWidget ( l, AlignCenter ); - hbox = new QHBoxLayout ( vbox ); + hbox = new QHBoxLayout ( vbox ); - grabItButton = new QPushButton( tr( "File" ), this, "GrabButton" ); - grabItButton ->setFocusPolicy( QWidget::TabFocus ); - hbox-> addWidget ( grabItButton ); + grabItButton = new QPushButton( tr( "File" ), this, "GrabButton" ); + grabItButton ->setFocusPolicy( QWidget::TabFocus ); + hbox-> addWidget ( grabItButton ); - scapButton = new QPushButton( tr( "Scap" ), this, "ScapButton" ); - scapButton ->setFocusPolicy( QWidget::TabFocus ); - hbox-> addWidget ( scapButton ); + scapButton = new QPushButton( tr( "Scap" ), this, "ScapButton" ); + scapButton ->setFocusPolicy( QWidget::TabFocus ); + hbox-> addWidget ( scapButton ); - setFixedSize ( sizeHint ( )); - setFocusPolicy ( QWidget::NoFocus ); + setFixedSize ( sizeHint ( )); + setFocusPolicy ( QWidget::NoFocus ); - grabTimer = new QTimer ( this, "grab timer"); - - connect ( grabTimer, SIGNAL( timeout ( )), this, SLOT( performGrab ( ))); - connect ( grabItButton, SIGNAL( clicked ( )), SLOT( slotGrab ( ))); - connect ( scapButton, SIGNAL( clicked ( )), SLOT( slotScap ( ))); + grabTimer = new QTimer ( this, "grab timer"); + + connect ( grabTimer, SIGNAL( timeout ( )), this, SLOT( performGrab ( ))); + connect ( grabItButton, SIGNAL( clicked ( )), SLOT( slotGrab ( ))); + connect ( scapButton, SIGNAL( clicked ( )), SLOT( slotScap ( ))); } void ScreenshotControl::slotGrab() { - buttonPushed = 1; - hide(); - - setFileName = FALSE; - if ( saveNamedCheck->isChecked()) { - setFileName = TRUE; - InputDialog *fileDlg; - - fileDlg = new InputDialog( 0 , tr("Name of screenshot "), TRUE, 0); - fileDlg->exec(); - fileDlg->raise(); - QString fileName, list; - if ( fileDlg->result() == 1 ) { - fileName = fileDlg->LineEdit1->text(); - - if (fileName.find("/", 0, TRUE) == -1) - FileNamePath = QDir::homeDirPath() + "/Documents/image/png/" + fileName; - else - FileNamePath = fileName; - - } - delete fileDlg; - } - - if ( delaySpin->value() ) - grabTimer->start( delaySpin->value() * 1000, true ); - else - show(); + buttonPushed = 1; + hide(); + + setFileName = FALSE; + if ( saveNamedCheck->isChecked()) { + setFileName = TRUE; + InputDialog *fileDlg; + + fileDlg = new InputDialog( 0 , tr("Name of screenshot "), TRUE, 0); + fileDlg->exec(); + fileDlg->raise(); + QString fileName, list; + if ( fileDlg->result() == 1 ) { + fileName = fileDlg->LineEdit1->text(); + + if (fileName.find("/", 0, TRUE) == -1) + FileNamePath = QDir::homeDirPath() + "/Documents/image/png/" + fileName; + else + FileNamePath = fileName; + + } + delete fileDlg; + } + + if ( delaySpin->value() ) + grabTimer->start( delaySpin->value() * 1000, true ); + else + show(); } void ScreenshotControl::slotScap() { - buttonPushed = 2; - hide(); + buttonPushed = 2; + hide(); - if ( delaySpin->value() ) - grabTimer->start( delaySpin->value() * 1000, true ); - else - show(); + if ( delaySpin->value() ) + grabTimer->start( delaySpin->value() * 1000, true ); + else + show(); } void ScreenshotControl::savePixmap() { - DocLnk lnk; - QString fileName; - - if ( setFileName) { - fileName = FileNamePath; - //not sure why this is needed here, but it forgets fileName - // if this is below the braces - - if (fileName.right(3) != "png") - fileName = fileName + ".png"; - lnk.setFile(fileName); //sets File property - qDebug("saving file " + fileName); - snapshot.save( fileName, "PNG"); - QFileInfo fi( fileName); - lnk.setName( fi.fileName()); //sets file name - - if (!lnk.writeLink()) - qDebug("Writing doclink did not work"); - } - else { - - fileName = "sc_" + TimeString::dateString( QDateTime::currentDateTime(), false, true); - fileName.replace(QRegExp("'"), ""); - fileName.replace(QRegExp(" "), "_"); - fileName.replace(QRegExp(":"), "."); - fileName.replace(QRegExp(","), ""); - QString dirName = QDir::homeDirPath() + "/Documents/image/png/"; - - if ( !QDir( dirName).exists() ) { - qDebug("making dir " + dirName); - QString msg = "mkdir -p " + dirName; - system(msg.latin1()); - } - fileName = dirName + fileName; - if (fileName.right(3) != "png") - fileName = fileName + ".png"; - lnk.setFile(fileName); //sets File property - qDebug("saving file " + fileName); - snapshot.save( fileName, "PNG"); - QFileInfo fi( fileName); - lnk.setName( fi.fileName()); //sets file name - - if (!lnk.writeLink()) - qDebug("Writing doclink did not work"); - - } - - QPEApplication::beep(); + DocLnk lnk; + QString fileName; + + if ( setFileName) { + fileName = FileNamePath; + //not sure why this is needed here, but it forgets fileName + // if this is below the braces + + if (fileName.right(3) != "png") + fileName = fileName + ".png"; + lnk.setFile(fileName); //sets File property + qDebug("saving file " + fileName); + snapshot.save( fileName, "PNG"); + QFileInfo fi( fileName); + lnk.setName( fi.fileName()); //sets file name + + if (!lnk.writeLink()) + qDebug("Writing doclink did not work"); + } + else { + + fileName = "sc_" + QDateTime::currentDateTime().toString(); + fileName.replace(QRegExp("'"), ""); + fileName.replace(QRegExp(" "), "_"); + fileName.replace(QRegExp(":"), "."); + fileName.replace(QRegExp(","), ""); + QString dirName = QDir::homeDirPath() + "/Documents/image/png/"; + + if ( !QDir( dirName).exists() ) { + qDebug("making dir " + dirName); + QString msg = "mkdir -p " + dirName; + system(msg.latin1()); + } + fileName = dirName + fileName; + if (fileName.right(3) != "png") + fileName = fileName + ".png"; + lnk.setFile(fileName); //sets File property + qDebug("saving file " + fileName); + snapshot.save( fileName, "PNG"); + QFileInfo fi( fileName); + lnk.setName( fi.fileName()); //sets file name + + if (!lnk.writeLink()) + qDebug("Writing doclink did not work"); + + } + + QPEApplication::beep(); } void ScreenshotControl::performGrab() { - snapshot = QPixmap::grabWindow( QPEApplication::desktop()->winId(), 0, 0, QApplication::desktop()->width(), QApplication::desktop()->height() ); - - if (buttonPushed == 1) { - qDebug("grabbing screen"); - grabTimer->stop(); - show(); - qApp->processEvents(); - savePixmap(); - } - else { - grabTimer->stop(); - - struct sockaddr_in raddr; - struct hostent *rhost_info; - int sock = -1; - bool ok = false; - - if (( rhost_info = (struct hostent *) ::gethostbyname ((char *) SCAP_hostname )) != 0 ) { - ::memset ( &raddr, 0, sizeof (struct sockaddr_in)); - ::memcpy ( &raddr. sin_addr, rhost_info-> h_addr, rhost_info-> h_length ); - raddr. sin_family = rhost_info-> h_addrtype; - raddr. sin_port = htons ( SCAP_port ); - - if (( sock = ::socket ( AF_INET, SOCK_STREAM, 0 )) >= 0 ) - { - if ( ::connect ( sock, (struct sockaddr *) & raddr, sizeof (struct sockaddr)) >= 0 ) { - QString header; - - header = "POST /scap/capture.cgi?%1+%2 HTTP/1.1\n" // 1: model / 2: user - "Content-length: 153600\n" - "Content-Type: image/gif\n" - "Host: %4\n" // 3: scap host - "\n"; - - header = header. arg ( "" ). arg ( ::getenv ( "USER" )). arg ( SCAP_hostname ); - - QPixmap pix; - - if ( snapshot. width ( ) == 320 && snapshot. height ( ) == 240 ) - { - pix = snapshot; - } - else if ( snapshot. width ( ) == 240 && snapshot. height ( ) == 320 ) - { - pix = snapshot. xForm ( QWMatrix ( ). rotate ( 90 )); - } - - if ( !pix. isNull ( )) - { - const char *ascii = header. latin1 ( ); - uint ascii_len = ::strlen ( ascii ); - - ::write ( sock, ascii, ascii_len ); - - QImage img = pix. convertToImage ( ). convertDepth ( 16 ); - ::write ( sock, img. bits ( ), img.numBytes ( )); - - ok = true; - } - } - ::close ( sock ); - } - } - if ( ok ) - QMessageBox::information ( 0, tr( "Success" ), QString ( "<p>%1</p>" ). arg ( tr( "Screenshot was uploaded to %1" )). arg ( SCAP_hostname )); - else - QMessageBox::warning ( 0, tr( "Error" ), QString ( "<p>%1</p>" ). arg ( tr( "Connection to %1 failed." )). arg ( SCAP_hostname )); - } + snapshot = QPixmap::grabWindow( QPEApplication::desktop()->winId(), 0, 0, QApplication::desktop()->width(), QApplication::desktop()->height() ); + + if (buttonPushed == 1) { + qDebug("grabbing screen"); + grabTimer->stop(); + show(); + qApp->processEvents(); + savePixmap(); + } + else { + grabTimer->stop(); + + struct sockaddr_in raddr; + struct hostent *rhost_info; + int sock = -1; + bool ok = false; + + if (( rhost_info = (struct hostent *) ::gethostbyname ((char *) SCAP_hostname )) != 0 ) { + ::memset ( &raddr, 0, sizeof (struct sockaddr_in)); + ::memcpy ( &raddr. sin_addr, rhost_info-> h_addr, rhost_info-> h_length ); + raddr. sin_family = rhost_info-> h_addrtype; + raddr. sin_port = htons ( SCAP_port ); + + if (( sock = ::socket ( AF_INET, SOCK_STREAM, 0 )) >= 0 ) + { + if ( ::connect ( sock, (struct sockaddr *) & raddr, sizeof (struct sockaddr)) >= 0 ) { + QString header; + + header = "POST /scap/capture.cgi?%1+%2 HTTP/1.1\n" // 1: model / 2: user + "Content-length: 153600\n" + "Content-Type: image/gif\n" + "Host: %4\n" // 3: scap host + "\n"; + + header = header. arg ( "" ). arg ( ::getenv ( "USER" )). arg ( SCAP_hostname ); + + QPixmap pix; + + if ( snapshot. width ( ) == 320 && snapshot. height ( ) == 240 ) + { + pix = snapshot; + } + else if ( snapshot. width ( ) == 240 && snapshot. height ( ) == 320 ) + { + pix = snapshot. xForm ( QWMatrix ( ). rotate ( 90 )); + } + + if ( !pix. isNull ( )) + { + const char *ascii = header. latin1 ( ); + uint ascii_len = ::strlen ( ascii ); + + ::write ( sock, ascii, ascii_len ); + + QImage img = pix. convertToImage ( ). convertDepth ( 16 ); + ::write ( sock, img. bits ( ), img.numBytes ( )); + + ok = true; + } + } + ::close ( sock ); + } + } + if ( ok ) + QMessageBox::information ( 0, tr( "Success" ), QString ( "<p>%1</p>" ). arg ( tr( "Screenshot was uploaded to %1" )). arg ( SCAP_hostname )); + else + QMessageBox::warning ( 0, tr( "Error" ), QString ( "<p>%1</p>" ). arg ( tr( "Connection to %1 failed." )). arg ( SCAP_hostname )); + } } //=========================================================================== ScreenshotApplet::ScreenshotApplet( QWidget *parent, const char *name ) - : QWidget( parent, name ) + : QWidget( parent, name ) { - setFixedHeight( 18 ); - setFixedWidth( 14 ); - - m_icon = QPixmap ((const char **) snapshot_xpm ); + setFixedHeight( 18 ); + setFixedWidth( 14 ); + + m_icon = QPixmap ((const char **) snapshot_xpm ); } ScreenshotApplet::~ScreenshotApplet() { } void ScreenshotApplet::mousePressEvent( QMouseEvent *) { - ScreenshotControl *sc = new ScreenshotControl ( ); - QPoint curPos = mapToGlobal ( QPoint ( 0, 0 )); - sc-> move ( curPos. x ( ) - ( sc-> sizeHint ( ). width ( ) - width ( )) / 2, - curPos. y ( ) - sc-> sizeHint ( ). height ( )); - sc-> show ( ); + ScreenshotControl *sc = new ScreenshotControl ( ); + QPoint curPos = mapToGlobal ( QPoint ( 0, 0 )); + sc-> move ( curPos. x ( ) - ( sc-> sizeHint ( ). width ( ) - width ( )) / 2, + curPos. y ( ) - sc-> sizeHint ( ). height ( )); + sc-> show ( ); } void ScreenshotApplet::paintEvent( QPaintEvent* ) { - QPainter p ( this ); - p. drawPixmap ( 0, 1, m_icon ); + QPainter p ( this ); + p. drawPixmap ( 0, 1, m_icon ); } |