-rw-r--r-- | libopie2/opieui/odialog.cpp | 16 | ||||
-rw-r--r-- | libopie2/opieui/odialog.h | 10 | ||||
-rw-r--r-- | libopie2/opieui/oimageeffect.cpp | 41 | ||||
-rw-r--r-- | libopie2/opieui/olistview.cpp | 20 | ||||
-rw-r--r-- | libopie2/opieui/opieui.pro | 22 | ||||
-rw-r--r-- | libopie2/opieui/oseparator.cpp | 12 | ||||
-rw-r--r-- | libopie2/opieui/oversatileview.cpp | 25 |
7 files changed, 75 insertions, 71 deletions
diff --git a/libopie2/opieui/odialog.cpp b/libopie2/opieui/odialog.cpp index 00a7a7e..4d269d4 100644 --- a/libopie2/opieui/odialog.cpp +++ b/libopie2/opieui/odialog.cpp | |||
@@ -1,16 +1,15 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the Opie Project | 2 | This file is part of the Opie Project |
3 | 3 | Copyright (C) 2003 Michael 'Mickey' Lauer <mickey@Vanille.de> | |
4 | Copyright (C) 2003 Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> | ||
5 | =. | 4 | =. |
6 | .=l. | 5 | .=l. |
7 | .>+-= | 6 | .>+-= |
8 | _;:, .> :=|. This program is free software; you can | 7 | _;:, .> :=|. This program is free software; you can |
9 | .> <`_, > . <= redistribute it and/or modify it under | 8 | .> <`_, > . <= redistribute it and/or modify it under |
10 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 9 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
11 | .="- .-=="i, .._ License as published by the Free Software | 10 | .="- .-=="i, .._ License as published by the Free Software |
12 | - . .-<_> .<> Foundation; either version 2 of the License, | 11 | - . .-<_> .<> Foundation; either version 2 of the License, |
13 | ._= =} : or (at your option) any later version. | 12 | ._= =} : or (at your option) any later version. |
14 | .%`+i> _;_. | 13 | .%`+i> _;_. |
15 | .i_,=:_. -<s. This program is distributed in the hope that | 14 | .i_,=:_. -<s. This program is distributed in the hope that |
16 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 15 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
@@ -22,32 +21,35 @@ | |||
22 | : = ...= . :.=- | 21 | : = ...= . :.=- |
23 | -. .:....=;==+<; You should have received a copy of the GNU | 22 | -. .:....=;==+<; You should have received a copy of the GNU |
24 | -_. . . )=. = Library General Public License along with | 23 | -_. . . )=. = Library General Public License along with |
25 | -- :-=` this library; see the file COPYING.LIB. | 24 | -- :-=` this library; see the file COPYING.LIB. |
26 | If not, write to the Free Software Foundation, | 25 | If not, write to the Free Software Foundation, |
27 | Inc., 59 Temple Place - Suite 330, | 26 | Inc., 59 Temple Place - Suite 330, |
28 | Boston, MA 02111-1307, USA. | 27 | Boston, MA 02111-1307, USA. |
29 | 28 | ||
30 | */ | 29 | */ |
31 | 30 | ||
32 | #include <opie2/odialog.h> | 31 | #include <opie2/odialog.h> |
33 | 32 | ||
34 | int ODialog::mMarginSize = 5; // 11 like in KDialog is probably too much for PDA | 33 | #warning Make Margin and Spacing device dependend and configurable! |
35 | int ODialog::mSpacingSize = 2; // 6 like in KDialog is probably too much for PDA | 34 | |
35 | int ODialog::mMarginSize = 5; | ||
36 | int ODialog::mSpacingSize = 2; | ||
36 | 37 | ||
37 | ODialog::ODialog(QWidget *parent, const char *name, bool modal, WFlags f) | 38 | ODialog::ODialog(QWidget *parent, const char *name, bool modal, WFlags f) |
38 | : QDialog(parent, name, modal, f) | 39 | :QDialog(parent, name, modal, f) |
39 | { | 40 | { |
41 | // d = new ODialogPrivate(); | ||
40 | } | 42 | } |
41 | 43 | ||
42 | int ODialog::marginHint() | 44 | int ODialog::marginHint() |
43 | { | 45 | { |
44 | return( mMarginSize ); | 46 | return( mMarginSize ); |
45 | } | 47 | } |
46 | 48 | ||
47 | 49 | ||
48 | int ODialog::spacingHint() | 50 | int ODialog::spacingHint() |
49 | { | 51 | { |
50 | return( mSpacingSize ); | 52 | return( mSpacingSize ); |
51 | } | 53 | } |
52 | 54 | ||
53 | // Placeholder for even more sophisticed things | 55 | // Placeholder for even more sophisticed things |
diff --git a/libopie2/opieui/odialog.h b/libopie2/opieui/odialog.h index 4116ed7..ceff612 100644 --- a/libopie2/opieui/odialog.h +++ b/libopie2/opieui/odialog.h | |||
@@ -1,16 +1,15 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the Opie Project | 2 | This file is part of the Opie Project |
3 | 3 | (C) 2003 Michael 'Mickey' Lauer <mickey@Vanille.de> | |
4 | (C) 2003 Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> | ||
5 | =. | 4 | =. |
6 | .=l. | 5 | .=l. |
7 | .>+-= | 6 | .>+-= |
8 | _;:, .> :=|. This program is free software; you can | 7 | _;:, .> :=|. This program is free software; you can |
9 | .> <`_, > . <= redistribute it and/or modify it under | 8 | .> <`_, > . <= redistribute it and/or modify it under |
10 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 9 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
11 | .="- .-=="i, .._ License as published by the Free Software | 10 | .="- .-=="i, .._ License as published by the Free Software |
12 | - . .-<_> .<> Foundation; either version 2 of the License, | 11 | - . .-<_> .<> Foundation; either version 2 of the License, |
13 | ._= =} : or (at your option) any later version. | 12 | ._= =} : or (at your option) any later version. |
14 | .%`+i> _;_. | 13 | .%`+i> _;_. |
15 | .i_,=:_. -<s. This program is distributed in the hope that | 14 | .i_,=:_. -<s. This program is distributed in the hope that |
16 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 15 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
@@ -40,27 +39,30 @@ class QLayoutItem; | |||
40 | * Dialog with extended nonmodal support and methods for OPIE standard | 39 | * Dialog with extended nonmodal support and methods for OPIE standard |
41 | * compliance. | 40 | * compliance. |
42 | * | 41 | * |
43 | * The @ref marginHint() and @ref spacingHint() sizes shall be used | 42 | * The @ref marginHint() and @ref spacingHint() sizes shall be used |
44 | * whenever you layout the interior of a dialog. One special note. If | 43 | * whenever you layout the interior of a dialog. One special note. If |
45 | * you make your own action buttons (OK, Cancel etc), the space | 44 | * you make your own action buttons (OK, Cancel etc), the space |
46 | * beteween the buttons shall be @ref spacingHint(), whereas the space | 45 | * beteween the buttons shall be @ref spacingHint(), whereas the space |
47 | * above, below, to the right and to the left shall be @ref marginHint(). | 46 | * above, below, to the right and to the left shall be @ref marginHint(). |
48 | * If you add a separator line above the buttons, there shall be a | 47 | * If you add a separator line above the buttons, there shall be a |
49 | * @ref marginHint() between the buttons and the separator and a | 48 | * @ref marginHint() between the buttons and the separator and a |
50 | * @ref marginHint() above the separator as well. | 49 | * @ref marginHint() above the separator as well. |
51 | * | 50 | * |
52 | * @author Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> | 51 | * @author Michael 'Mickey' Lauer <mickey@Vanille.de> |
53 | */ | 52 | */ |
53 | |||
54 | // lets fix up Qt instead! Size does matter. -zecke | 54 | // lets fix up Qt instead! Size does matter. -zecke |
55 | // while that may be true, reducing maintainance effort for the future does also matter - | ||
56 | // and I believe that maintaining a patch against QtE is more work than our classes -mml | ||
55 | 57 | ||
56 | class ODialog : public QDialog | 58 | class ODialog : public QDialog |
57 | { | 59 | { |
58 | Q_OBJECT | 60 | Q_OBJECT |
59 | 61 | ||
60 | public: | 62 | public: |
61 | 63 | ||
62 | /** | 64 | /** |
63 | * Constructor. | 65 | * Constructor. |
64 | * | 66 | * |
65 | * Takes the same arguments as @ref QDialog. | 67 | * Takes the same arguments as @ref QDialog. |
66 | */ | 68 | */ |
@@ -74,16 +76,16 @@ class ODialog : public QDialog | |||
74 | 76 | ||
75 | /** | 77 | /** |
76 | * Return the number of pixels you shall use between | 78 | * Return the number of pixels you shall use between |
77 | * widgets inside a dialog according to the KDE standard. | 79 | * widgets inside a dialog according to the KDE standard. |
78 | */ | 80 | */ |
79 | static int spacingHint(); | 81 | static int spacingHint(); |
80 | 82 | ||
81 | private: | 83 | private: |
82 | static int mMarginSize; | 84 | static int mMarginSize; |
83 | static int mSpacingSize; | 85 | static int mSpacingSize; |
84 | 86 | ||
85 | class ODialogPrivate; | 87 | class ODialogPrivate; |
86 | ODialogPrivate *d; // d pointer always needed! -zecke | 88 | ODialogPrivate *d; |
87 | 89 | ||
88 | }; | 90 | }; |
89 | #endif // ODIALOG_H | 91 | #endif // ODIALOG_H |
diff --git a/libopie2/opieui/oimageeffect.cpp b/libopie2/opieui/oimageeffect.cpp index 01e7c6f..9a58bb9 100644 --- a/libopie2/opieui/oimageeffect.cpp +++ b/libopie2/opieui/oimageeffect.cpp | |||
@@ -25,25 +25,26 @@ THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | |||
25 | (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | 25 | (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
26 | THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 26 | THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
27 | 27 | ||
28 | */ | 28 | */ |
29 | 29 | ||
30 | // $Id$ | 30 | // $Id$ |
31 | 31 | ||
32 | #include <math.h> | 32 | #include <math.h> |
33 | 33 | ||
34 | #include <qimage.h> | 34 | #include <qimage.h> |
35 | #include <stdlib.h> | 35 | #include <stdlib.h> |
36 | 36 | ||
37 | #include "oimageeffect.h" | 37 | #include <opie2/oimageeffect.h> |
38 | #include <opie2/odebug.h> | ||
38 | 39 | ||
39 | #define MaxRGB 255L | 40 | #define MaxRGB 255L |
40 | #define DegreesToRadians(x) ((x)*M_PI/180.0) | 41 | #define DegreesToRadians(x) ((x)*M_PI/180.0) |
41 | 42 | ||
42 | using namespace std; | 43 | using namespace std; |
43 | 44 | ||
44 | inline unsigned int intensityValue(unsigned int color) | 45 | inline unsigned int intensityValue(unsigned int color) |
45 | { | 46 | { |
46 | return((unsigned int)((0.299*qRed(color) + | 47 | return((unsigned int)((0.299*qRed(color) + |
47 | 0.587*qGreen(color) + | 48 | 0.587*qGreen(color) + |
48 | 0.1140000000000001*qBlue(color)))); | 49 | 0.1140000000000001*qBlue(color)))); |
49 | } | 50 | } |
@@ -54,25 +55,25 @@ inline unsigned int intensityValue(unsigned int color) | |||
54 | // | 55 | // |
55 | //====================================================================== | 56 | //====================================================================== |
56 | 57 | ||
57 | QImage OImageEffect::gradient(const QSize &size, const QColor &ca, | 58 | QImage OImageEffect::gradient(const QSize &size, const QColor &ca, |
58 | const QColor &cb, GradientType eff, int ncols) | 59 | const QColor &cb, GradientType eff, int ncols) |
59 | { | 60 | { |
60 | int rDiff, gDiff, bDiff; | 61 | int rDiff, gDiff, bDiff; |
61 | int rca, gca, bca, rcb, gcb, bcb; | 62 | int rca, gca, bca, rcb, gcb, bcb; |
62 | 63 | ||
63 | QImage image(size, 32); | 64 | QImage image(size, 32); |
64 | 65 | ||
65 | if (size.width() == 0 || size.height() == 0) { | 66 | if (size.width() == 0 || size.height() == 0) { |
66 | qDebug( "WARNING: OImageEffect::gradient: invalid image" ); | 67 | odebug << "WARNING: OImageEffect::gradient: invalid image" << oendl; |
67 | return image; | 68 | return image; |
68 | } | 69 | } |
69 | 70 | ||
70 | register int x, y; | 71 | register int x, y; |
71 | 72 | ||
72 | rDiff = (rcb = cb.red()) - (rca = ca.red()); | 73 | rDiff = (rcb = cb.red()) - (rca = ca.red()); |
73 | gDiff = (gcb = cb.green()) - (gca = ca.green()); | 74 | gDiff = (gcb = cb.green()) - (gca = ca.green()); |
74 | bDiff = (bcb = cb.blue()) - (bca = ca.blue()); | 75 | bDiff = (bcb = cb.blue()) - (bca = ca.blue()); |
75 | 76 | ||
76 | if( eff == VerticalGradient || eff == HorizontalGradient ){ | 77 | if( eff == VerticalGradient || eff == HorizontalGradient ){ |
77 | 78 | ||
78 | uint *p; | 79 | uint *p; |
@@ -340,25 +341,25 @@ QImage OImageEffect::unbalancedGradient(const QSize &size, const QColor &ca, | |||
340 | // float xbal = xfactor/5000.; | 341 | // float xbal = xfactor/5000.; |
341 | // float ybal = yfactor/5000.; | 342 | // float ybal = yfactor/5000.; |
342 | float xbal = xfactor/30./size.width(); | 343 | float xbal = xfactor/30./size.width(); |
343 | float ybal = yfactor/30./size.height(); | 344 | float ybal = yfactor/30./size.height(); |
344 | float rat; | 345 | float rat; |
345 | 346 | ||
346 | int rDiff, gDiff, bDiff; | 347 | int rDiff, gDiff, bDiff; |
347 | int rca, gca, bca, rcb, gcb, bcb; | 348 | int rca, gca, bca, rcb, gcb, bcb; |
348 | 349 | ||
349 | QImage image(size, 32); | 350 | QImage image(size, 32); |
350 | 351 | ||
351 | if (size.width() == 0 || size.height() == 0) { | 352 | if (size.width() == 0 || size.height() == 0) { |
352 | qDebug( "WARNING: OImageEffect::unbalancedGradient : invalid image" ); | 353 | odebug << "WARNING: OImageEffect::unbalancedGradient : invalid image" << oendl; |
353 | return image; | 354 | return image; |
354 | } | 355 | } |
355 | 356 | ||
356 | register int x, y; | 357 | register int x, y; |
357 | unsigned int *scanline; | 358 | unsigned int *scanline; |
358 | 359 | ||
359 | rDiff = (rcb = cb.red()) - (rca = ca.red()); | 360 | rDiff = (rcb = cb.red()) - (rca = ca.red()); |
360 | gDiff = (gcb = cb.green()) - (gca = ca.green()); | 361 | gDiff = (gcb = cb.green()) - (gca = ca.green()); |
361 | bDiff = (bcb = cb.blue()) - (bca = ca.blue()); | 362 | bDiff = (bcb = cb.blue()) - (bca = ca.blue()); |
362 | 363 | ||
363 | if( eff == VerticalGradient || eff == HorizontalGradient){ | 364 | if( eff == VerticalGradient || eff == HorizontalGradient){ |
364 | QColor cRow; | 365 | QColor cRow; |
@@ -559,25 +560,25 @@ QImage OImageEffect::unbalancedGradient(const QSize &size, const QColor &ca, | |||
559 | 560 | ||
560 | 561 | ||
561 | /* This builds a 256 byte unsigned char lookup table with all | 562 | /* This builds a 256 byte unsigned char lookup table with all |
562 | * the possible percent values prior to applying the effect, then uses | 563 | * the possible percent values prior to applying the effect, then uses |
563 | * integer math for the pixels. For any image larger than 9x9 this will be | 564 | * integer math for the pixels. For any image larger than 9x9 this will be |
564 | * less expensive than doing a float operation on the 3 color components of | 565 | * less expensive than doing a float operation on the 3 color components of |
565 | * each pixel. (mosfet) | 566 | * each pixel. (mosfet) |
566 | */ | 567 | */ |
567 | 568 | ||
568 | QImage& OImageEffect::intensity(QImage &image, float percent) | 569 | QImage& OImageEffect::intensity(QImage &image, float percent) |
569 | { | 570 | { |
570 | if (image.width() == 0 || image.height() == 0) { | 571 | if (image.width() == 0 || image.height() == 0) { |
571 | qDebug( "WARNING: OImageEffect::intensity : invalid image" ); | 572 | odebug << "WARNING: OImageEffect::intensity : invalid image" << oendl; |
572 | return image; | 573 | return image; |
573 | } | 574 | } |
574 | 575 | ||
575 | int segColors = image.depth() > 8 ? 256 : image.numColors(); | 576 | int segColors = image.depth() > 8 ? 256 : image.numColors(); |
576 | unsigned char *segTbl = new unsigned char[segColors]; | 577 | unsigned char *segTbl = new unsigned char[segColors]; |
577 | int pixels = image.depth() > 8 ? image.width()*image.height() : | 578 | int pixels = image.depth() > 8 ? image.width()*image.height() : |
578 | image.numColors(); | 579 | image.numColors(); |
579 | unsigned int *data = image.depth() > 8 ? (unsigned int *)image.bits() : | 580 | unsigned int *data = image.depth() > 8 ? (unsigned int *)image.bits() : |
580 | (unsigned int *)image.colorTable(); | 581 | (unsigned int *)image.colorTable(); |
581 | 582 | ||
582 | bool brighten = (percent >= 0); | 583 | bool brighten = (percent >= 0); |
583 | if(percent < 0) | 584 | if(percent < 0) |
@@ -624,25 +625,25 @@ QImage& OImageEffect::intensity(QImage &image, float percent) | |||
624 | data[i] = qRgba(r, g, b, a); | 625 | data[i] = qRgba(r, g, b, a); |
625 | } | 626 | } |
626 | } | 627 | } |
627 | delete [] segTbl; | 628 | delete [] segTbl; |
628 | 629 | ||
629 | return image; | 630 | return image; |
630 | } | 631 | } |
631 | 632 | ||
632 | QImage& OImageEffect::channelIntensity(QImage &image, float percent, | 633 | QImage& OImageEffect::channelIntensity(QImage &image, float percent, |
633 | RGBComponent channel) | 634 | RGBComponent channel) |
634 | { | 635 | { |
635 | if (image.width() == 0 || image.height() == 0) { | 636 | if (image.width() == 0 || image.height() == 0) { |
636 | qDebug( "WARNING: OImageEffect::channelIntensity : invalid image" ); | 637 | odebug << "WARNING: OImageEffect::channelIntensity : invalid image" << oendl; |
637 | return image; | 638 | return image; |
638 | } | 639 | } |
639 | 640 | ||
640 | int segColors = image.depth() > 8 ? 256 : image.numColors(); | 641 | int segColors = image.depth() > 8 ? 256 : image.numColors(); |
641 | unsigned char *segTbl = new unsigned char[segColors]; | 642 | unsigned char *segTbl = new unsigned char[segColors]; |
642 | int pixels = image.depth() > 8 ? image.width()*image.height() : | 643 | int pixels = image.depth() > 8 ? image.width()*image.height() : |
643 | image.numColors(); | 644 | image.numColors(); |
644 | unsigned int *data = image.depth() > 8 ? (unsigned int *)image.bits() : | 645 | unsigned int *data = image.depth() > 8 ? (unsigned int *)image.bits() : |
645 | (unsigned int *)image.colorTable(); | 646 | (unsigned int *)image.colorTable(); |
646 | bool brighten = (percent >= 0); | 647 | bool brighten = (percent >= 0); |
647 | if(percent < 0) | 648 | if(percent < 0) |
648 | percent = -percent; | 649 | percent = -percent; |
@@ -714,25 +715,25 @@ QImage& OImageEffect::channelIntensity(QImage &image, float percent, | |||
714 | delete [] segTbl; | 715 | delete [] segTbl; |
715 | 716 | ||
716 | return image; | 717 | return image; |
717 | } | 718 | } |
718 | 719 | ||
719 | // Modulate an image with an RBG channel of another image | 720 | // Modulate an image with an RBG channel of another image |
720 | // | 721 | // |
721 | QImage& OImageEffect::modulate(QImage &image, QImage &modImage, bool reverse, | 722 | QImage& OImageEffect::modulate(QImage &image, QImage &modImage, bool reverse, |
722 | ModulationType type, int factor, RGBComponent channel) | 723 | ModulationType type, int factor, RGBComponent channel) |
723 | { | 724 | { |
724 | if (image.width() == 0 || image.height() == 0 || | 725 | if (image.width() == 0 || image.height() == 0 || |
725 | modImage.width() == 0 || modImage.height() == 0) { | 726 | modImage.width() == 0 || modImage.height() == 0) { |
726 | qDebug( "WARNING: OImageEffect::modulate : invalid image" ); | 727 | odebug << "WARNING: OImageEffect::modulate : invalid image" << oendl; |
727 | return image; | 728 | return image; |
728 | } | 729 | } |
729 | 730 | ||
730 | int r, g, b, h, s, v, a; | 731 | int r, g, b, h, s, v, a; |
731 | QColor clr; | 732 | QColor clr; |
732 | int mod=0; | 733 | int mod=0; |
733 | unsigned int x1, x2, y1, y2; | 734 | unsigned int x1, x2, y1, y2; |
734 | register int x, y; | 735 | register int x, y; |
735 | 736 | ||
736 | // for image, we handle only depth 32 | 737 | // for image, we handle only depth 32 |
737 | if (image.depth()<32) image = image.convertDepth(32); | 738 | if (image.depth()<32) image = image.convertDepth(32); |
738 | 739 | ||
@@ -843,25 +844,25 @@ QImage& OImageEffect::modulate(QImage &image, QImage &modImage, bool reverse, | |||
843 | // Blend effects | 844 | // Blend effects |
844 | // | 845 | // |
845 | //====================================================================== | 846 | //====================================================================== |
846 | 847 | ||
847 | 848 | ||
848 | // Nice and fast direct pixel manipulation | 849 | // Nice and fast direct pixel manipulation |
849 | QImage& OImageEffect::blend(const QColor& clr, QImage& dst, float opacity) | 850 | QImage& OImageEffect::blend(const QColor& clr, QImage& dst, float opacity) |
850 | { | 851 | { |
851 | if (dst.width() <= 0 || dst.height() <= 0) | 852 | if (dst.width() <= 0 || dst.height() <= 0) |
852 | return dst; | 853 | return dst; |
853 | 854 | ||
854 | if (opacity < 0.0 || opacity > 1.0) { | 855 | if (opacity < 0.0 || opacity > 1.0) { |
855 | qDebug( "WARNING: OImageEffect::blend : invalid opacity. Range [0, 1] "); | 856 | odebug << "WARNING: OImageEffect::blend : invalid opacity. Range [0, 1] " << oendl; |
856 | return dst; | 857 | return dst; |
857 | } | 858 | } |
858 | 859 | ||
859 | int depth = dst.depth(); | 860 | int depth = dst.depth(); |
860 | if (depth != 32) | 861 | if (depth != 32) |
861 | dst = dst.convertDepth(32); | 862 | dst = dst.convertDepth(32); |
862 | 863 | ||
863 | int pixels = dst.width() * dst.height(); | 864 | int pixels = dst.width() * dst.height(); |
864 | int rcol, gcol, bcol; | 865 | int rcol, gcol, bcol; |
865 | clr.rgb(&rcol, &gcol, &bcol); | 866 | clr.rgb(&rcol, &gcol, &bcol); |
866 | 867 | ||
867 | #ifdef WORDS_BIGENDIAN // ARGB (skip alpha) | 868 | #ifdef WORDS_BIGENDIAN // ARGB (skip alpha) |
@@ -886,30 +887,30 @@ QImage& OImageEffect::blend(const QColor& clr, QImage& dst, float opacity) | |||
886 | return dst; | 887 | return dst; |
887 | } | 888 | } |
888 | 889 | ||
889 | // Nice and fast direct pixel manipulation | 890 | // Nice and fast direct pixel manipulation |
890 | QImage& OImageEffect::blend(QImage& src, QImage& dst, float opacity) | 891 | QImage& OImageEffect::blend(QImage& src, QImage& dst, float opacity) |
891 | { | 892 | { |
892 | if (src.width() <= 0 || src.height() <= 0) | 893 | if (src.width() <= 0 || src.height() <= 0) |
893 | return dst; | 894 | return dst; |
894 | if (dst.width() <= 0 || dst.height() <= 0) | 895 | if (dst.width() <= 0 || dst.height() <= 0) |
895 | return dst; | 896 | return dst; |
896 | 897 | ||
897 | if (src.width() != dst.width() || src.height() != dst.height()) { | 898 | if (src.width() != dst.width() || src.height() != dst.height()) { |
898 | qDebug( "WARNING: OImageEffect::blend : src and destination images are not the same size" ); | 899 | odebug << "WARNING: OImageEffect::blend : src and destination images are not the same size" << oendl; |
899 | return dst; | 900 | return dst; |
900 | } | 901 | } |
901 | 902 | ||
902 | if (opacity < 0.0 || opacity > 1.0) { | 903 | if (opacity < 0.0 || opacity > 1.0) { |
903 | qDebug( "WARNING: OImageEffect::blend : invalid opacity. Range [0, 1]" ); | 904 | odebug << "WARNING: OImageEffect::blend : invalid opacity. Range [0, 1]" << oendl; |
904 | return dst; | 905 | return dst; |
905 | } | 906 | } |
906 | 907 | ||
907 | if (src.depth() != 32) src = src.convertDepth(32); | 908 | if (src.depth() != 32) src = src.convertDepth(32); |
908 | if (dst.depth() != 32) dst = dst.convertDepth(32); | 909 | if (dst.depth() != 32) dst = dst.convertDepth(32); |
909 | 910 | ||
910 | int pixels = src.width() * src.height(); | 911 | int pixels = src.width() * src.height(); |
911 | #ifdef WORDS_BIGENDIAN // ARGB (skip alpha) | 912 | #ifdef WORDS_BIGENDIAN // ARGB (skip alpha) |
912 | register unsigned char *data1 = (unsigned char *)dst.bits() + 1; | 913 | register unsigned char *data1 = (unsigned char *)dst.bits() + 1; |
913 | register unsigned char *data2 = (unsigned char *)src.bits() + 1; | 914 | register unsigned char *data2 = (unsigned char *)src.bits() + 1; |
914 | #else // BGRA | 915 | #else // BGRA |
915 | register unsigned char *data1 = (unsigned char *)dst.bits(); | 916 | register unsigned char *data1 = (unsigned char *)dst.bits(); |
@@ -931,25 +932,25 @@ QImage& OImageEffect::blend(QImage& src, QImage& dst, float opacity) | |||
931 | data2++; | 932 | data2++; |
932 | } | 933 | } |
933 | 934 | ||
934 | return dst; | 935 | return dst; |
935 | } | 936 | } |
936 | 937 | ||
937 | 938 | ||
938 | QImage& OImageEffect::blend(QImage &image, float initial_intensity, | 939 | QImage& OImageEffect::blend(QImage &image, float initial_intensity, |
939 | const QColor &bgnd, GradientType eff, | 940 | const QColor &bgnd, GradientType eff, |
940 | bool anti_dir) | 941 | bool anti_dir) |
941 | { | 942 | { |
942 | if (image.width() == 0 || image.height() == 0 || image.depth()!=32 ) { | 943 | if (image.width() == 0 || image.height() == 0 || image.depth()!=32 ) { |
943 | qDebug( "WARNING: OImageEffect::blend : invalid image" ); | 944 | odebug << "WARNING: OImageEffect::blend : invalid image" << oendl; |
944 | return image; | 945 | return image; |
945 | } | 946 | } |
946 | 947 | ||
947 | int r_bgnd = bgnd.red(), g_bgnd = bgnd.green(), b_bgnd = bgnd.blue(); | 948 | int r_bgnd = bgnd.red(), g_bgnd = bgnd.green(), b_bgnd = bgnd.blue(); |
948 | int r, g, b; | 949 | int r, g, b; |
949 | int ind; | 950 | int ind; |
950 | 951 | ||
951 | unsigned int xi, xf, yi, yf; | 952 | unsigned int xi, xf, yi, yf; |
952 | unsigned int a; | 953 | unsigned int a; |
953 | 954 | ||
954 | // check the boundaries of the initial intesity param | 955 | // check the boundaries of the initial intesity param |
955 | float unaffected = 1; | 956 | float unaffected = 1; |
@@ -1124,25 +1125,25 @@ QImage& OImageEffect::blend(QImage &image, float initial_intensity, | |||
1124 | g = qGreen(data[ind]) + (int)(intensity * | 1125 | g = qGreen(data[ind]) + (int)(intensity * |
1125 | (g_bgnd - qGreen(data[ind]))); | 1126 | (g_bgnd - qGreen(data[ind]))); |
1126 | b = qBlue (data[ind]) + (int)(intensity * | 1127 | b = qBlue (data[ind]) + (int)(intensity * |
1127 | (b_bgnd - qBlue (data[ind]))); | 1128 | (b_bgnd - qBlue (data[ind]))); |
1128 | if (r > 255) r = 255; if (r < 0 ) r = 0; | 1129 | if (r > 255) r = 255; if (r < 0 ) r = 0; |
1129 | if (g > 255) g = 255; if (g < 0 ) g = 0; | 1130 | if (g > 255) g = 255; if (g < 0 ) g = 0; |
1130 | if (b > 255) b = 255; if (b < 0 ) b = 0; | 1131 | if (b > 255) b = 255; if (b < 0 ) b = 0; |
1131 | a = qAlpha(data[ind]); | 1132 | a = qAlpha(data[ind]); |
1132 | data[ind] = qRgba(r, g, b, a); | 1133 | data[ind] = qRgba(r, g, b, a); |
1133 | } | 1134 | } |
1134 | } | 1135 | } |
1135 | } | 1136 | } |
1136 | else qDebug( "OImageEffect::blend effect not implemented" ); | 1137 | else odebug << "OImageEffect::blend effect not implemented" << oendl; |
1137 | return image; | 1138 | return image; |
1138 | } | 1139 | } |
1139 | 1140 | ||
1140 | // Not very efficient as we create a third big image... | 1141 | // Not very efficient as we create a third big image... |
1141 | // | 1142 | // |
1142 | QImage& OImageEffect::blend(QImage &image1, QImage &image2, | 1143 | QImage& OImageEffect::blend(QImage &image1, QImage &image2, |
1143 | GradientType gt, int xf, int yf) | 1144 | GradientType gt, int xf, int yf) |
1144 | { | 1145 | { |
1145 | if (image1.width() == 0 || image1.height() == 0 || | 1146 | if (image1.width() == 0 || image1.height() == 0 || |
1146 | image2.width() == 0 || image2.height() == 0) | 1147 | image2.width() == 0 || image2.height() == 0) |
1147 | return image1; | 1148 | return image1; |
1148 | 1149 | ||
@@ -1154,25 +1155,25 @@ QImage& OImageEffect::blend(QImage &image1, QImage &image2, | |||
1154 | 1155 | ||
1155 | return blend(image1,image2,image3, Red); // Channel to use is arbitrary | 1156 | return blend(image1,image2,image3, Red); // Channel to use is arbitrary |
1156 | } | 1157 | } |
1157 | 1158 | ||
1158 | // Blend image2 into image1, using an RBG channel of blendImage | 1159 | // Blend image2 into image1, using an RBG channel of blendImage |
1159 | // | 1160 | // |
1160 | QImage& OImageEffect::blend(QImage &image1, QImage &image2, | 1161 | QImage& OImageEffect::blend(QImage &image1, QImage &image2, |
1161 | QImage &blendImage, RGBComponent channel) | 1162 | QImage &blendImage, RGBComponent channel) |
1162 | { | 1163 | { |
1163 | if (image1.width() == 0 || image1.height() == 0 || | 1164 | if (image1.width() == 0 || image1.height() == 0 || |
1164 | image2.width() == 0 || image2.height() == 0 || | 1165 | image2.width() == 0 || image2.height() == 0 || |
1165 | blendImage.width() == 0 || blendImage.height() == 0) { | 1166 | blendImage.width() == 0 || blendImage.height() == 0) { |
1166 | qDebug( "OImageEffect::blend effect invalid image" ); | 1167 | odebug << "OImageEffect::blend effect invalid image" << oendl; |
1167 | return image1; | 1168 | return image1; |
1168 | } | 1169 | } |
1169 | 1170 | ||
1170 | int r, g, b; | 1171 | int r, g, b; |
1171 | int ind1, ind2, ind3; | 1172 | int ind1, ind2, ind3; |
1172 | 1173 | ||
1173 | unsigned int x1, x2, x3, y1, y2, y3; | 1174 | unsigned int x1, x2, x3, y1, y2, y3; |
1174 | unsigned int a; | 1175 | unsigned int a; |
1175 | 1176 | ||
1176 | register int x, y; | 1177 | register int x, y; |
1177 | 1178 | ||
1178 | // for image1 and image2, we only handle depth 32 | 1179 | // for image1 and image2, we only handle depth 32 |
@@ -1252,25 +1253,25 @@ unsigned int OImageEffect::uHash(unsigned int c) | |||
1252 | ng = g + (g >> 3); ng = ng < g ? ~0 : ng; | 1253 | ng = g + (g >> 3); ng = ng < g ? ~0 : ng; |
1253 | nb = b + (b >> 3); nb = nb < b ? ~0 : nb; | 1254 | nb = b + (b >> 3); nb = nb < b ? ~0 : nb; |
1254 | 1255 | ||
1255 | return qRgba(nr, ng, nb, a); | 1256 | return qRgba(nr, ng, nb, a); |
1256 | } | 1257 | } |
1257 | 1258 | ||
1258 | 1259 | ||
1259 | // ----------------------------------------------------------------------------- | 1260 | // ----------------------------------------------------------------------------- |
1260 | 1261 | ||
1261 | QImage& OImageEffect::hash(QImage &image, Lighting lite, unsigned int spacing) | 1262 | QImage& OImageEffect::hash(QImage &image, Lighting lite, unsigned int spacing) |
1262 | { | 1263 | { |
1263 | if (image.width() == 0 || image.height() == 0) { | 1264 | if (image.width() == 0 || image.height() == 0) { |
1264 | qDebug( "OImageEffect::hash effect invalid image" ); | 1265 | odebug << "OImageEffect::hash effect invalid image" << oendl; |
1265 | return image; | 1266 | return image; |
1266 | } | 1267 | } |
1267 | 1268 | ||
1268 | register int x, y; | 1269 | register int x, y; |
1269 | unsigned int *data = (unsigned int *)image.bits(); | 1270 | unsigned int *data = (unsigned int *)image.bits(); |
1270 | unsigned int ind; | 1271 | unsigned int ind; |
1271 | 1272 | ||
1272 | //CT no need to do it if not enough space | 1273 | //CT no need to do it if not enough space |
1273 | if ((lite == NorthLite || | 1274 | if ((lite == NorthLite || |
1274 | lite == SouthLite)&& | 1275 | lite == SouthLite)&& |
1275 | (unsigned)image.height() < 2+spacing) return image; | 1276 | (unsigned)image.height() < 2+spacing) return image; |
1276 | if ((lite == EastLite || | 1277 | if ((lite == EastLite || |
@@ -1760,25 +1761,25 @@ bool OImageEffect::blend( | |||
1760 | const QImage & upper, | 1761 | const QImage & upper, |
1761 | const QImage & lower, | 1762 | const QImage & lower, |
1762 | QImage & output | 1763 | QImage & output |
1763 | ) | 1764 | ) |
1764 | { | 1765 | { |
1765 | if ( | 1766 | if ( |
1766 | upper.width() > lower.width() || | 1767 | upper.width() > lower.width() || |
1767 | upper.height() > lower.height() || | 1768 | upper.height() > lower.height() || |
1768 | upper.depth() != 32 || | 1769 | upper.depth() != 32 || |
1769 | lower.depth() != 32 | 1770 | lower.depth() != 32 |
1770 | ) | 1771 | ) |
1771 | { | 1772 | { |
1772 | qDebug( "OImageEffect::blend : Sizes not correct" ); | 1773 | odebug << "OImageEffect::blend : Sizes not correct" << oendl; |
1773 | return false; | 1774 | return false; |
1774 | } | 1775 | } |
1775 | 1776 | ||
1776 | output = lower.copy(); | 1777 | output = lower.copy(); |
1777 | 1778 | ||
1778 | register uchar *i, *o; | 1779 | register uchar *i, *o; |
1779 | register int a; | 1780 | register int a; |
1780 | register int col; | 1781 | register int col; |
1781 | register int w = upper.width(); | 1782 | register int w = upper.width(); |
1782 | int row(upper.height() - 1); | 1783 | int row(upper.height() - 1); |
1783 | 1784 | ||
1784 | do { | 1785 | do { |
@@ -1977,25 +1978,25 @@ void OImageEffect::normalize(QImage &img) | |||
1977 | { | 1978 | { |
1978 | int *histogram, threshold_intensity, intense; | 1979 | int *histogram, threshold_intensity, intense; |
1979 | int x, y, i; | 1980 | int x, y, i; |
1980 | 1981 | ||
1981 | unsigned int gray_value; | 1982 | unsigned int gray_value; |
1982 | unsigned int *normalize_map; | 1983 | unsigned int *normalize_map; |
1983 | unsigned int high, low; | 1984 | unsigned int high, low; |
1984 | 1985 | ||
1985 | // allocate histogram and normalize map | 1986 | // allocate histogram and normalize map |
1986 | histogram = (int *)calloc(MaxRGB+1, sizeof(int)); | 1987 | histogram = (int *)calloc(MaxRGB+1, sizeof(int)); |
1987 | normalize_map = (unsigned int *)malloc((MaxRGB+1)*sizeof(unsigned int)); | 1988 | normalize_map = (unsigned int *)malloc((MaxRGB+1)*sizeof(unsigned int)); |
1988 | if(!normalize_map || !histogram){ | 1989 | if(!normalize_map || !histogram){ |
1989 | qWarning("Unable to allocate normalize histogram and map"); | 1990 | owarn << "Unable to allocate normalize histogram and map" << oendl; |
1990 | free(normalize_map); | 1991 | free(normalize_map); |
1991 | free(histogram); | 1992 | free(histogram); |
1992 | return; | 1993 | return; |
1993 | } | 1994 | } |
1994 | 1995 | ||
1995 | // form histogram | 1996 | // form histogram |
1996 | if(img.depth() > 8){ // DirectClass | 1997 | if(img.depth() > 8){ // DirectClass |
1997 | unsigned int *data; | 1998 | unsigned int *data; |
1998 | for(y=0; y < img.height(); ++y){ | 1999 | for(y=0; y < img.height(); ++y){ |
1999 | data = (unsigned int *)img.scanLine(y); | 2000 | data = (unsigned int *)img.scanLine(y); |
2000 | for(x=0; x < img.width(); ++x){ | 2001 | for(x=0; x < img.width(); ++x){ |
2001 | gray_value = intensityValue(data[x]); | 2002 | gray_value = intensityValue(data[x]); |
@@ -2093,25 +2094,25 @@ void OImageEffect::equalize(QImage &img) | |||
2093 | { | 2094 | { |
2094 | int *histogram, *map, *equalize_map; | 2095 | int *histogram, *map, *equalize_map; |
2095 | int x, y, i, j; | 2096 | int x, y, i, j; |
2096 | 2097 | ||
2097 | unsigned int high, low; | 2098 | unsigned int high, low; |
2098 | 2099 | ||
2099 | // allocate histogram and maps | 2100 | // allocate histogram and maps |
2100 | histogram = (int *)calloc(MaxRGB+1, sizeof(int)); | 2101 | histogram = (int *)calloc(MaxRGB+1, sizeof(int)); |
2101 | map = (int *)malloc((MaxRGB+1)*sizeof(unsigned int)); | 2102 | map = (int *)malloc((MaxRGB+1)*sizeof(unsigned int)); |
2102 | equalize_map = (int *)malloc((MaxRGB+1)*sizeof(unsigned int)); | 2103 | equalize_map = (int *)malloc((MaxRGB+1)*sizeof(unsigned int)); |
2103 | 2104 | ||
2104 | if(!histogram || !map || !equalize_map){ | 2105 | if(!histogram || !map || !equalize_map){ |
2105 | qWarning("Unable to allocate equalize histogram and maps"); | 2106 | owarn << "Unable to allocate equalize histogram and maps" << oendl; |
2106 | free(histogram); | 2107 | free(histogram); |
2107 | free(map); | 2108 | free(map); |
2108 | free(equalize_map); | 2109 | free(equalize_map); |
2109 | return; | 2110 | return; |
2110 | } | 2111 | } |
2111 | // form histogram | 2112 | // form histogram |
2112 | if(img.depth() > 8){ // DirectClass | 2113 | if(img.depth() > 8){ // DirectClass |
2113 | unsigned int *data; | 2114 | unsigned int *data; |
2114 | for(y=0; y < img.height(); ++y){ | 2115 | for(y=0; y < img.height(); ++y){ |
2115 | data = (unsigned int *)img.scanLine(y); | 2116 | data = (unsigned int *)img.scanLine(y); |
2116 | for(x=0; x < img.width(); ++x){ | 2117 | for(x=0; x < img.width(); ++x){ |
2117 | histogram[intensityValue(data[x])]++; | 2118 | histogram[intensityValue(data[x])]++; |
@@ -2178,43 +2179,43 @@ QImage OImageEffect::sample(QImage &src, int w, int h) | |||
2178 | { | 2179 | { |
2179 | if(w == src.width() && h == src.height()) | 2180 | if(w == src.width() && h == src.height()) |
2180 | return(src); | 2181 | return(src); |
2181 | 2182 | ||
2182 | double *x_offset, *y_offset; | 2183 | double *x_offset, *y_offset; |
2183 | int j, k, y; | 2184 | int j, k, y; |
2184 | register int x; | 2185 | register int x; |
2185 | QImage dest(w, h, src.depth()); | 2186 | QImage dest(w, h, src.depth()); |
2186 | 2187 | ||
2187 | x_offset = (double *)malloc(w*sizeof(double)); | 2188 | x_offset = (double *)malloc(w*sizeof(double)); |
2188 | y_offset = (double *)malloc(h*sizeof(double)); | 2189 | y_offset = (double *)malloc(h*sizeof(double)); |
2189 | if(!x_offset || !y_offset){ | 2190 | if(!x_offset || !y_offset){ |
2190 | qWarning("Unable to allocate pixels buffer"); | 2191 | owarn << "Unable to allocate pixels buffer" << oendl; |
2191 | free(x_offset); | 2192 | free(x_offset); |
2192 | free(y_offset); | 2193 | free(y_offset); |
2193 | return(src); | 2194 | return(src); |
2194 | } | 2195 | } |
2195 | 2196 | ||
2196 | // init pixel offsets | 2197 | // init pixel offsets |
2197 | for(x=0; x < w; ++x) | 2198 | for(x=0; x < w; ++x) |
2198 | x_offset[x] = x*src.width()/((double)w); | 2199 | x_offset[x] = x*src.width()/((double)w); |
2199 | for(y=0; y < h; ++y) | 2200 | for(y=0; y < h; ++y) |
2200 | y_offset[y] = y*src.height()/((double)h); | 2201 | y_offset[y] = y*src.height()/((double)h); |
2201 | 2202 | ||
2202 | // sample each row | 2203 | // sample each row |
2203 | if(src.depth() > 8){ // DirectClass source image | 2204 | if(src.depth() > 8){ // DirectClass source image |
2204 | unsigned int *srcData, *destData; | 2205 | unsigned int *srcData, *destData; |
2205 | unsigned int *pixels; | 2206 | unsigned int *pixels; |
2206 | pixels = (unsigned int *)malloc(src.width()*sizeof(unsigned int)); | 2207 | pixels = (unsigned int *)malloc(src.width()*sizeof(unsigned int)); |
2207 | if(!pixels){ | 2208 | if(!pixels){ |
2208 | qWarning("Unable to allocate pixels buffer"); | 2209 | owarn << "Unable to allocate pixels buffer" << oendl; |
2209 | free(pixels); | 2210 | free(pixels); |
2210 | free(x_offset); | 2211 | free(x_offset); |
2211 | free(y_offset); | 2212 | free(y_offset); |
2212 | return(src); | 2213 | return(src); |
2213 | } | 2214 | } |
2214 | j = (-1); | 2215 | j = (-1); |
2215 | for(y=0; y < h; ++y){ | 2216 | for(y=0; y < h; ++y){ |
2216 | destData = (unsigned int *)dest.scanLine(y); | 2217 | destData = (unsigned int *)dest.scanLine(y); |
2217 | if(j != y_offset[y]){ | 2218 | if(j != y_offset[y]){ |
2218 | // read a scan line | 2219 | // read a scan line |
2219 | j = (int)(y_offset[y]); | 2220 | j = (int)(y_offset[y]); |
2220 | srcData = (unsigned int *)src.scanLine(j); | 2221 | srcData = (unsigned int *)src.scanLine(j); |
@@ -2224,25 +2225,25 @@ QImage OImageEffect::sample(QImage &src, int w, int h) | |||
2224 | for(x=0; x < w; ++x){ | 2225 | for(x=0; x < w; ++x){ |
2225 | k = (int)(x_offset[x]); | 2226 | k = (int)(x_offset[x]); |
2226 | destData[x] = pixels[k]; | 2227 | destData[x] = pixels[k]; |
2227 | } | 2228 | } |
2228 | } | 2229 | } |
2229 | free(pixels); | 2230 | free(pixels); |
2230 | } | 2231 | } |
2231 | else{ // PsudeoClass source image | 2232 | else{ // PsudeoClass source image |
2232 | unsigned char *srcData, *destData; | 2233 | unsigned char *srcData, *destData; |
2233 | unsigned char *pixels; | 2234 | unsigned char *pixels; |
2234 | pixels = (unsigned char *)malloc(src.width()*sizeof(unsigned char)); | 2235 | pixels = (unsigned char *)malloc(src.width()*sizeof(unsigned char)); |
2235 | if(!pixels){ | 2236 | if(!pixels){ |
2236 | qWarning("Unable to allocate pixels buffer"); | 2237 | owarn << "Unable to allocate pixels buffer" << oendl; |
2237 | free(pixels); | 2238 | free(pixels); |
2238 | free(x_offset); | 2239 | free(x_offset); |
2239 | free(y_offset); | 2240 | free(y_offset); |
2240 | return(src); | 2241 | return(src); |
2241 | } | 2242 | } |
2242 | // copy colortable | 2243 | // copy colortable |
2243 | dest.setNumColors(src.numColors()); | 2244 | dest.setNumColors(src.numColors()); |
2244 | (void)memcpy(dest.colorTable(), src.colorTable(), | 2245 | (void)memcpy(dest.colorTable(), src.colorTable(), |
2245 | src.numColors()*sizeof(unsigned int)); | 2246 | src.numColors()*sizeof(unsigned int)); |
2246 | 2247 | ||
2247 | // sample image | 2248 | // sample image |
2248 | j = (-1); | 2249 | j = (-1); |
@@ -3063,25 +3064,25 @@ QImage OImageEffect::wave(QImage &src, double amplitude, double wavelength, | |||
3063 | *q=interpolateColor(&src, x, (int)(y-sine_map[x]), background); | 3064 | *q=interpolateColor(&src, x, (int)(y-sine_map[x]), background); |
3064 | ++q; | 3065 | ++q; |
3065 | } | 3066 | } |
3066 | } | 3067 | } |
3067 | free(sine_map); | 3068 | free(sine_map); |
3068 | return(dest); | 3069 | return(dest); |
3069 | } | 3070 | } |
3070 | 3071 | ||
3071 | QImage OImageEffect::oilPaint(QImage &src, int radius) | 3072 | QImage OImageEffect::oilPaint(QImage &src, int radius) |
3072 | { | 3073 | { |
3073 | // TODO 8bpp src! | 3074 | // TODO 8bpp src! |
3074 | if(src.depth() < 32){ | 3075 | if(src.depth() < 32){ |
3075 | qWarning("Oil Paint source image < 32bpp. Convert before using!"); | 3076 | owarn << "Oil Paint source image < 32bpp. Convert before using!" << oendl; |
3076 | return(src); | 3077 | return(src); |
3077 | } | 3078 | } |
3078 | int j, k, i, x, y; | 3079 | int j, k, i, x, y; |
3079 | unsigned int *histogram; | 3080 | unsigned int *histogram; |
3080 | unsigned int *s; | 3081 | unsigned int *s; |
3081 | unsigned int count; | 3082 | unsigned int count; |
3082 | 3083 | ||
3083 | unsigned int *srcData, *destData; | 3084 | unsigned int *srcData, *destData; |
3084 | 3085 | ||
3085 | QImage dest(src); | 3086 | QImage dest(src); |
3086 | dest.detach(); | 3087 | dest.detach(); |
3087 | histogram = (unsigned int *) malloc((MaxRGB+1)*sizeof(unsigned int)); | 3088 | histogram = (unsigned int *) malloc((MaxRGB+1)*sizeof(unsigned int)); |
diff --git a/libopie2/opieui/olistview.cpp b/libopie2/opieui/olistview.cpp index ec503dd..38f3fe2 100644 --- a/libopie2/opieui/olistview.cpp +++ b/libopie2/opieui/olistview.cpp | |||
@@ -1,16 +1,15 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the Opie Project | 2 | This file is part of the Opie Project |
3 | 3 | =. (C) 2003 Michael 'Mickey' Lauer <mickey@Vanille.de> | |
4 | =. (C) 2003 Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> | ||
5 | .=l. | 4 | .=l. |
6 | .>+-= | 5 | .>+-= |
7 | _;:, .> :=|. This program is free software; you can | 6 | _;:, .> :=|. This program is free software; you can |
8 | .> <`_, > . <= redistribute it and/or modify it under | 7 | .> <`_, > . <= redistribute it and/or modify it under |
9 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 8 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
10 | .="- .-=="i, .._ License as published by the Free Software | 9 | .="- .-=="i, .._ License as published by the Free Software |
11 | - . .-<_> .<> Foundation; either version 2 of the License, | 10 | - . .-<_> .<> Foundation; either version 2 of the License, |
12 | ._= =} : or (at your option) any later version. | 11 | ._= =} : or (at your option) any later version. |
13 | .%`+i> _;_. | 12 | .%`+i> _;_. |
14 | .i_,=:_. -<s. This program is distributed in the hope that | 13 | .i_,=:_. -<s. This program is distributed in the hope that |
15 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
16 | : .. .:, . . . without even the implied warranty of | 15 | : .. .:, . . . without even the implied warranty of |
@@ -28,24 +27,25 @@ | |||
28 | 27 | ||
29 | */ | 28 | */ |
30 | 29 | ||
31 | /* QT */ | 30 | /* QT */ |
32 | 31 | ||
33 | #include <qcolor.h> | 32 | #include <qcolor.h> |
34 | #include <qheader.h> | 33 | #include <qheader.h> |
35 | #include <qpainter.h> | 34 | #include <qpainter.h> |
36 | #include <qpixmap.h> | 35 | #include <qpixmap.h> |
37 | 36 | ||
38 | /* OPIE */ | 37 | /* OPIE */ |
39 | 38 | ||
39 | #include <opie2/odebug.h> | ||
40 | #include <opie2/olistview.h> | 40 | #include <opie2/olistview.h> |
41 | 41 | ||
42 | /*====================================================================================== | 42 | /*====================================================================================== |
43 | * OListView | 43 | * OListView |
44 | *======================================================================================*/ | 44 | *======================================================================================*/ |
45 | 45 | ||
46 | OListView::OListView( QWidget *parent, const char *name ) | 46 | OListView::OListView( QWidget *parent, const char *name ) |
47 | :QListView( parent, name ) | 47 | :QListView( parent, name ) |
48 | { | 48 | { |
49 | //FIXME: get from global settings and calculate ==> see oglobalsettings.* | 49 | //FIXME: get from global settings and calculate ==> see oglobalsettings.* |
50 | 50 | ||
51 | m_alternateBackground = QColor( 238, 246, 255 ); | 51 | m_alternateBackground = QColor( 238, 246, 255 ); |
@@ -133,56 +133,56 @@ void OListView::expand(QListViewItem *item) | |||
133 | ((OListViewItem*)item)->expand(); | 133 | ((OListViewItem*)item)->expand(); |
134 | } | 134 | } |
135 | 135 | ||
136 | OListViewItem* OListView::childFactory() | 136 | OListViewItem* OListView::childFactory() |
137 | { | 137 | { |
138 | return new OListViewItem( this ); | 138 | return new OListViewItem( this ); |
139 | } | 139 | } |
140 | 140 | ||
141 | #ifndef QT_NO_DATASTREAM | 141 | #ifndef QT_NO_DATASTREAM |
142 | void OListView::serializeTo( QDataStream& s ) const | 142 | void OListView::serializeTo( QDataStream& s ) const |
143 | { | 143 | { |
144 | #warning Caution... the binary format is still under construction... | 144 | #warning Caution... the binary format is still under construction... |
145 | qDebug( "storing OListView..." ); | 145 | odebug << "storing OListView..." << oendl; |
146 | 146 | ||
147 | // store number of columns and the labels | 147 | // store number of columns and the labels |
148 | s << columns(); | 148 | s << columns(); |
149 | for ( int i = 0; i < columns(); ++i ) | 149 | for ( int i = 0; i < columns(); ++i ) |
150 | s << columnText( i ); | 150 | s << columnText( i ); |
151 | 151 | ||
152 | // calculate the number of top-level items to serialize | 152 | // calculate the number of top-level items to serialize |
153 | int items = 0; | 153 | int items = 0; |
154 | QListViewItem* item = firstChild(); | 154 | QListViewItem* item = firstChild(); |
155 | while ( item ) | 155 | while ( item ) |
156 | { | 156 | { |
157 | item = item->nextSibling(); | 157 | item = item->nextSibling(); |
158 | items++; | 158 | items++; |
159 | } | 159 | } |
160 | 160 | ||
161 | // store number of items and the items itself | 161 | // store number of items and the items itself |
162 | s << items; | 162 | s << items; |
163 | item = firstChild(); | 163 | item = firstChild(); |
164 | for ( int i = 0; i < items; ++i ) | 164 | for ( int i = 0; i < items; ++i ) |
165 | { | 165 | { |
166 | s << *static_cast<OListViewItem*>( item ); | 166 | s << *static_cast<OListViewItem*>( item ); |
167 | item = item->nextSibling(); | 167 | item = item->nextSibling(); |
168 | } | 168 | } |
169 | 169 | ||
170 | qDebug( "OListview stored." ); | 170 | odebug << "OListview stored." << oendl; |
171 | } | 171 | } |
172 | 172 | ||
173 | void OListView::serializeFrom( QDataStream& s ) | 173 | void OListView::serializeFrom( QDataStream& s ) |
174 | { | 174 | { |
175 | #warning Caution... the binary format is still under construction... | 175 | #warning Caution... the binary format is still under construction... |
176 | qDebug( "loading OListView..." ); | 176 | odebug << "loading OListView..." << oendl; |
177 | 177 | ||
178 | int cols; | 178 | int cols; |
179 | s >> cols; | 179 | s >> cols; |
180 | qDebug( "read number of columns = %d", cols ); | 180 | qDebug( "read number of columns = %d", cols ); |
181 | 181 | ||
182 | while ( columns() < cols ) addColumn( QString::null ); | 182 | while ( columns() < cols ) addColumn( QString::null ); |
183 | 183 | ||
184 | for ( int i = 0; i < cols; ++i ) | 184 | for ( int i = 0; i < cols; ++i ) |
185 | { | 185 | { |
186 | QString coltext; | 186 | QString coltext; |
187 | s >> coltext; | 187 | s >> coltext; |
188 | qDebug( "read text '%s' for column %d", (const char*) coltext, i ); | 188 | qDebug( "read text '%s' for column %d", (const char*) coltext, i ); |
@@ -190,25 +190,25 @@ void OListView::serializeFrom( QDataStream& s ) | |||
190 | } | 190 | } |
191 | 191 | ||
192 | int items; | 192 | int items; |
193 | s >> items; | 193 | s >> items; |
194 | qDebug( "read number of items = %d", items ); | 194 | qDebug( "read number of items = %d", items ); |
195 | 195 | ||
196 | for ( int i = 0; i < items; ++i ) | 196 | for ( int i = 0; i < items; ++i ) |
197 | { | 197 | { |
198 | OListViewItem* item = childFactory(); | 198 | OListViewItem* item = childFactory(); |
199 | s >> *item; | 199 | s >> *item; |
200 | } | 200 | } |
201 | 201 | ||
202 | qDebug( "OListView loaded." ); | 202 | odebug << "OListView loaded." << oendl; |
203 | 203 | ||
204 | } | 204 | } |
205 | 205 | ||
206 | QDataStream& operator<<( QDataStream& s, const OListView& lv ) | 206 | QDataStream& operator<<( QDataStream& s, const OListView& lv ) |
207 | { | 207 | { |
208 | lv.serializeTo( s ); | 208 | lv.serializeTo( s ); |
209 | } | 209 | } |
210 | 210 | ||
211 | QDataStream& operator>>( QDataStream& s, OListView& lv ) | 211 | QDataStream& operator>>( QDataStream& s, OListView& lv ) |
212 | { | 212 | { |
213 | lv.serializeFrom( s ); | 213 | lv.serializeFrom( s ); |
214 | } | 214 | } |
@@ -368,25 +368,25 @@ void OListViewItem::paintCell(QPainter *p, const QColorGroup &cg, int column, in | |||
368 | 368 | ||
369 | 369 | ||
370 | OListViewItem* OListViewItem::childFactory() | 370 | OListViewItem* OListViewItem::childFactory() |
371 | { | 371 | { |
372 | return new OListViewItem( this ); | 372 | return new OListViewItem( this ); |
373 | } | 373 | } |
374 | 374 | ||
375 | 375 | ||
376 | #ifndef QT_NO_DATASTREAM | 376 | #ifndef QT_NO_DATASTREAM |
377 | void OListViewItem::serializeTo( QDataStream& s ) const | 377 | void OListViewItem::serializeTo( QDataStream& s ) const |
378 | { | 378 | { |
379 | #warning Caution... the binary format is still under construction... | 379 | #warning Caution... the binary format is still under construction... |
380 | qDebug( "storing OListViewItem..." ); | 380 | odebug << "storing OListViewItem..." << oendl; |
381 | 381 | ||
382 | // store item text | 382 | // store item text |
383 | for ( int i = 0; i < listView()->columns(); ++i ) | 383 | for ( int i = 0; i < listView()->columns(); ++i ) |
384 | { | 384 | { |
385 | s << text( i ); | 385 | s << text( i ); |
386 | } | 386 | } |
387 | 387 | ||
388 | // calculate the number of children to serialize | 388 | // calculate the number of children to serialize |
389 | int items = 0; | 389 | int items = 0; |
390 | QListViewItem* item = firstChild(); | 390 | QListViewItem* item = firstChild(); |
391 | while ( item ) | 391 | while ( item ) |
392 | { | 392 | { |
@@ -394,52 +394,52 @@ void OListViewItem::serializeTo( QDataStream& s ) const | |||
394 | items++; | 394 | items++; |
395 | } | 395 | } |
396 | 396 | ||
397 | // store number of items and the items itself | 397 | // store number of items and the items itself |
398 | s << items; | 398 | s << items; |
399 | item = firstChild(); | 399 | item = firstChild(); |
400 | for ( int i = 0; i < items; ++i ) | 400 | for ( int i = 0; i < items; ++i ) |
401 | { | 401 | { |
402 | s << *static_cast<OListViewItem*>( item ); | 402 | s << *static_cast<OListViewItem*>( item ); |
403 | item = item->nextSibling(); | 403 | item = item->nextSibling(); |
404 | } | 404 | } |
405 | 405 | ||
406 | qDebug( "OListviewItem stored." ); | 406 | odebug << "OListviewItem stored." << oendl; |
407 | } | 407 | } |
408 | 408 | ||
409 | 409 | ||
410 | void OListViewItem::serializeFrom( QDataStream& s ) | 410 | void OListViewItem::serializeFrom( QDataStream& s ) |
411 | { | 411 | { |
412 | #warning Caution... the binary format is still under construction... | 412 | #warning Caution... the binary format is still under construction... |
413 | qDebug( "loading OListViewItem..." ); | 413 | odebug << "loading OListViewItem..." << oendl; |
414 | 414 | ||
415 | for ( int i = 0; i < listView()->columns(); ++i ) | 415 | for ( int i = 0; i < listView()->columns(); ++i ) |
416 | { | 416 | { |
417 | QString coltext; | 417 | QString coltext; |
418 | s >> coltext; | 418 | s >> coltext; |
419 | qDebug( "read text '%s' for column %d", (const char*) coltext, i ); | 419 | qDebug( "read text '%s' for column %d", (const char*) coltext, i ); |
420 | setText( i, coltext ); | 420 | setText( i, coltext ); |
421 | } | 421 | } |
422 | 422 | ||
423 | int items; | 423 | int items; |
424 | s >> items; | 424 | s >> items; |
425 | qDebug( "read number of items = %d", items ); | 425 | qDebug( "read number of items = %d", items ); |
426 | 426 | ||
427 | for ( int i = 0; i < items; ++i ) | 427 | for ( int i = 0; i < items; ++i ) |
428 | { | 428 | { |
429 | OListViewItem* item = childFactory(); | 429 | OListViewItem* item = childFactory(); |
430 | s >> (*item); | 430 | s >> (*item); |
431 | } | 431 | } |
432 | 432 | ||
433 | qDebug( "OListViewItem loaded." ); | 433 | odebug << "OListViewItem loaded." << oendl; |
434 | } | 434 | } |
435 | 435 | ||
436 | 436 | ||
437 | QDataStream& operator<<( QDataStream& s, const OListViewItem& lvi ) | 437 | QDataStream& operator<<( QDataStream& s, const OListViewItem& lvi ) |
438 | { | 438 | { |
439 | lvi.serializeTo( s ); | 439 | lvi.serializeTo( s ); |
440 | } | 440 | } |
441 | 441 | ||
442 | 442 | ||
443 | QDataStream& operator>>( QDataStream& s, OListViewItem& lvi ) | 443 | QDataStream& operator>>( QDataStream& s, OListViewItem& lvi ) |
444 | { | 444 | { |
445 | lvi.serializeFrom( s ); | 445 | lvi.serializeFrom( s ); |
diff --git a/libopie2/opieui/opieui.pro b/libopie2/opieui/opieui.pro index b455602..61f9bbb 100644 --- a/libopie2/opieui/opieui.pro +++ b/libopie2/opieui/opieui.pro | |||
@@ -1,49 +1,47 @@ | |||
1 | TEMPLATE = lib | 1 | TEMPLATE = lib |
2 | CONFIG += qt warn_on debug | 2 | CONFIG += qt warn_on debug |
3 | DESTDIR = $(OPIEDIR)/lib | 3 | DESTDIR = $(OPIEDIR)/lib |
4 | HEADERS = olistview.h \ | 4 | HEADERS = olistview.h \ |
5 | oimageeffect.h \ | 5 | oimageeffect.h \ |
6 | opixmapeffect.h \ | 6 | opixmapeffect.h \ |
7 | opopupmenu.h \ | 7 | opopupmenu.h \ |
8 | opixmapprovider.h \ | 8 | opixmapprovider.h \ |
9 | oselector.h \ | 9 | oselector.h \ |
10 | oversatileview.h \ | 10 | oversatileview.h \ |
11 | oversatileviewitem.h \ | 11 | oversatileviewitem.h \ |
12 | odialog.h \ | 12 | odialog.h \ |
13 | omessagebox.h \ | 13 | omessagebox.h \ |
14 | oresource.h \ | 14 | oresource.h \ |
15 | oseparator.h | 15 | otaskbarapplet.h \ |
16 | oseparator.h | ||
16 | 17 | ||
17 | SOURCES = olistview.cpp \ | 18 | SOURCES = olistview.cpp \ |
18 | oimageeffect.cpp \ | 19 | oimageeffect.cpp \ |
19 | opixmapeffect.cpp \ | 20 | opixmapeffect.cpp \ |
20 | opopupmenu.cpp \ | 21 | opopupmenu.cpp \ |
21 | opixmapprovider.cpp \ | 22 | opixmapprovider.cpp \ |
22 | oselector.cpp \ | 23 | oselector.cpp \ |
23 | oversatileview.cpp \ | 24 | oversatileview.cpp \ |
24 | oversatileviewitem.cpp \ | 25 | oversatileviewitem.cpp \ |
25 | odialog.cpp \ | 26 | odialog.cpp \ |
26 | oresource.cpp \ | 27 | oresource.cpp \ |
27 | oseparator.cpp | 28 | otaskbarapplet.cpp \ |
29 | oseparator.cpp | ||
28 | 30 | ||
29 | INTERFACES = | 31 | INTERFACES = |
30 | TARGET = opieui2 | 32 | TARGET = opieui2 |
31 | VERSION = 1.8.2 | 33 | VERSION = 1.8.2 |
34 | |||
32 | INCLUDEPATH += $(OPIEDIR)/include | 35 | INCLUDEPATH += $(OPIEDIR)/include |
33 | DEPENDPATH += $(OPIEDIR)/include | 36 | DEPENDPATH += $(OPIEDIR)/include |
34 | LIBS += -lopiecore2 | ||
35 | MOC_DIR = moc | ||
36 | OBJECTS_DIR = obj | ||
37 | 37 | ||
38 | LIBS += -lopiecore2 | ||
38 | 39 | ||
39 | !contains( platform, x11 ) { | 40 | !contains( platform, x11 ) { |
40 | include ( $(OPIEDIR)/include.pro ) | 41 | include ( $(OPIEDIR)/include.pro ) |
41 | HEADERS += otaskbarapplet.h | ||
42 | SOURCES += otaskbarapplet.cpp | ||
43 | } | 42 | } |
44 | 43 | ||
45 | contains( platform, x11 ) { | 44 | contains( platform, x11 ) { |
46 | LIBS += -L$(OPIEDIR)/lib -Wl,-rpath,$(OPIEDIR)/lib | 45 | LIBS += -L$(OPIEDIR)/lib -Wl,-rpath,$(OPIEDIR)/lib |
47 | message( Warning: NO otaskbarapplet ATM ) | ||
48 | } | 46 | } |
49 | 47 | ||
diff --git a/libopie2/opieui/oseparator.cpp b/libopie2/opieui/oseparator.cpp index 85181dc..98d42c7 100644 --- a/libopie2/opieui/oseparator.cpp +++ b/libopie2/opieui/oseparator.cpp | |||
@@ -1,15 +1,14 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the Opie Project | 2 | This file is part of the Opie Project |
3 | |||
4 | Copyright (C) 2003 Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> | 3 | Copyright (C) 2003 Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> |
5 | Copyright (C) 1997 Michael Roth <mroth@wirlweb.de> | 4 | Copyright (C) 1997 Michael Roth <mroth@wirlweb.de> |
6 | =. | 5 | =. |
7 | .=l. | 6 | .=l. |
8 | .>+-= | 7 | .>+-= |
9 | _;:, .> :=|. This program is free software; you can | 8 | _;:, .> :=|. This program is free software; you can |
10 | .> <`_, > . <= redistribute it and/or modify it under | 9 | .> <`_, > . <= redistribute it and/or modify it under |
11 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 10 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
12 | .="- .-=="i, .._ License as published by the Free Software | 11 | .="- .-=="i, .._ License as published by the Free Software |
13 | - . .-<_> .<> Foundation; either version 2 of the License, | 12 | - . .-<_> .<> Foundation; either version 2 of the License, |
14 | ._= =} : or (at your option) any later version. | 13 | ._= =} : or (at your option) any later version. |
15 | .%`+i> _;_. | 14 | .%`+i> _;_. |
@@ -21,32 +20,33 @@ | |||
21 | ..}^=.= = ; Library General Public License for more | 20 | ..}^=.= = ; Library General Public License for more |
22 | ++= -. .` .: details. | 21 | ++= -. .` .: details. |
23 | : = ...= . :.=- | 22 | : = ...= . :.=- |
24 | -. .:....=;==+<; You should have received a copy of the GNU | 23 | -. .:....=;==+<; You should have received a copy of the GNU |
25 | -_. . . )=. = Library General Public License along with | 24 | -_. . . )=. = Library General Public License along with |
26 | -- :-=` this library; see the file COPYING.LIB. | 25 | -- :-=` this library; see the file COPYING.LIB. |
27 | If not, write to the Free Software Foundation, | 26 | If not, write to the Free Software Foundation, |
28 | Inc., 59 Temple Place - Suite 330, | 27 | Inc., 59 Temple Place - Suite 330, |
29 | Boston, MA 02111-1307, USA. | 28 | Boston, MA 02111-1307, USA. |
30 | 29 | ||
31 | */ | 30 | */ |
32 | 31 | ||
33 | /* QT */ | ||
34 | |||
35 | #include <qstyle.h> | ||
36 | |||
37 | /* OPIE */ | 32 | /* OPIE */ |
38 | 33 | ||
34 | #include <opie2/odebug.h> | ||
39 | #include <opie2/oseparator.h> | 35 | #include <opie2/oseparator.h> |
40 | 36 | ||
37 | /* QT */ | ||
38 | |||
39 | #include <qstyle.h> | ||
40 | |||
41 | OSeparator::OSeparator(QWidget* parent, const char* name, WFlags f) | 41 | OSeparator::OSeparator(QWidget* parent, const char* name, WFlags f) |
42 | : QFrame(parent, name, f) | 42 | : QFrame(parent, name, f) |
43 | { | 43 | { |
44 | setLineWidth(1); | 44 | setLineWidth(1); |
45 | setMidLineWidth(0); | 45 | setMidLineWidth(0); |
46 | setOrientation( HLine ); | 46 | setOrientation( HLine ); |
47 | } | 47 | } |
48 | 48 | ||
49 | 49 | ||
50 | 50 | ||
51 | OSeparator::OSeparator(int orientation, QWidget* parent, const char* name, WFlags f) | 51 | OSeparator::OSeparator(int orientation, QWidget* parent, const char* name, WFlags f) |
52 | : QFrame(parent, name, f) | 52 | : QFrame(parent, name, f) |
@@ -60,25 +60,25 @@ OSeparator::OSeparator(int orientation, QWidget* parent, const char* name, WFlag | |||
60 | 60 | ||
61 | void OSeparator::setOrientation(int orientation) | 61 | void OSeparator::setOrientation(int orientation) |
62 | { | 62 | { |
63 | switch(orientation) | 63 | switch(orientation) |
64 | { | 64 | { |
65 | case Vertical: | 65 | case Vertical: |
66 | case VLine: | 66 | case VLine: |
67 | setFrameStyle( QFrame::VLine | QFrame::Sunken ); | 67 | setFrameStyle( QFrame::VLine | QFrame::Sunken ); |
68 | setMinimumSize(2, 0); | 68 | setMinimumSize(2, 0); |
69 | break; | 69 | break; |
70 | 70 | ||
71 | default: | 71 | default: |
72 | qWarning( "OSeparator::setOrientation(): invalid orientation, using default orientation HLine" ); | 72 | owarn << "OSeparator::setOrientation(): invalid orientation, using default orientation HLine" << oendl; |
73 | 73 | ||
74 | case Horizontal: | 74 | case Horizontal: |
75 | case HLine: | 75 | case HLine: |
76 | setFrameStyle( QFrame::HLine | QFrame::Sunken ); | 76 | setFrameStyle( QFrame::HLine | QFrame::Sunken ); |
77 | setMinimumSize(0, 2); | 77 | setMinimumSize(0, 2); |
78 | break; | 78 | break; |
79 | } | 79 | } |
80 | } | 80 | } |
81 | 81 | ||
82 | 82 | ||
83 | 83 | ||
84 | int OSeparator::orientation() const | 84 | int OSeparator::orientation() const |
diff --git a/libopie2/opieui/oversatileview.cpp b/libopie2/opieui/oversatileview.cpp index 6808539..65fe3d8 100644 --- a/libopie2/opieui/oversatileview.cpp +++ b/libopie2/opieui/oversatileview.cpp | |||
@@ -19,46 +19,47 @@ | |||
19 | ..}^=.= = ; Library General Public License for more | 19 | ..}^=.= = ; Library General Public License for more |
20 | ++= -. .` .: details. | 20 | ++= -. .` .: details. |
21 | : = ...= . :.=- | 21 | : = ...= . :.=- |
22 | -. .:....=;==+<; You should have received a copy of the GNU | 22 | -. .:....=;==+<; You should have received a copy of the GNU |
23 | -_. . . )=. = Library General Public License along with | 23 | -_. . . )=. = Library General Public License along with |
24 | -- :-=` this library; see the file COPYING.LIB. | 24 | -- :-=` this library; see the file COPYING.LIB. |
25 | If not, write to the Free Software Foundation, | 25 | If not, write to the Free Software Foundation, |
26 | Inc., 59 Temple Place - Suite 330, | 26 | Inc., 59 Temple Place - Suite 330, |
27 | Boston, MA 02111-1307, USA. | 27 | Boston, MA 02111-1307, USA. |
28 | 28 | ||
29 | */ | 29 | */ |
30 | 30 | ||
31 | /* OPIE */ | ||
32 | |||
33 | #include <opie2/odebug.h> | ||
34 | #include <opie2/oversatileview.h> | ||
35 | #include <opie2/oversatileviewitem.h> | ||
36 | #include <opie2/olistview.h> | ||
37 | |||
31 | /* QT */ | 38 | /* QT */ |
32 | 39 | ||
33 | #include <qaction.h> | 40 | #include <qaction.h> |
34 | #include <qbrush.h> | 41 | #include <qbrush.h> |
35 | #include <qfont.h> | 42 | #include <qfont.h> |
36 | #include <qiconset.h> | 43 | #include <qiconset.h> |
37 | #include <qiconview.h> | 44 | #include <qiconview.h> |
38 | #include <qlistview.h> | 45 | #include <qlistview.h> |
39 | #include <qpalette.h> | 46 | #include <qpalette.h> |
40 | #include <qpoint.h> | 47 | #include <qpoint.h> |
41 | #include <qpopupmenu.h> | 48 | #include <qpopupmenu.h> |
42 | #include <qrect.h> | 49 | #include <qrect.h> |
43 | #include <qsize.h> | 50 | #include <qsize.h> |
44 | #include <qstring.h> | 51 | #include <qstring.h> |
45 | #include <qwidgetstack.h> | 52 | #include <qwidgetstack.h> |
46 | 53 | ||
47 | /* OPIE */ | ||
48 | |||
49 | #include <opie2/oversatileview.h> | ||
50 | #include <opie2/oversatileviewitem.h> | ||
51 | #include <opie2/olistview.h> | ||
52 | |||
53 | /* XPM */ | 54 | /* XPM */ |
54 | static const char * view_icon_xpm[] = { | 55 | static const char * view_icon_xpm[] = { |
55 | "16 16 16 1", | 56 | "16 16 16 1", |
56 | " c None", | 57 | " c None", |
57 | ".c #87BD88", | 58 | ".c #87BD88", |
58 | "+c #8BBE8B", | 59 | "+c #8BBE8B", |
59 | "@c #81BA81", | 60 | "@c #81BA81", |
60 | "#c #6DAF6D", | 61 | "#c #6DAF6D", |
61 | "$c #87BD87", | 62 | "$c #87BD87", |
62 | "%c #FCFDFC", | 63 | "%c #FCFDFC", |
63 | "&c #AED0AE", | 64 | "&c #AED0AE", |
64 | "*c #4E9C4C", | 65 | "*c #4E9C4C", |
@@ -280,25 +281,25 @@ void OVersatileView::setDefaultPixmaps( int mode, QPixmap& leaf, QPixmap& opened | |||
280 | _treeleaf = leaf; | 281 | _treeleaf = leaf; |
281 | _treeopened = opened; | 282 | _treeopened = opened; |
282 | _treeclosed = closed; | 283 | _treeclosed = closed; |
283 | } | 284 | } |
284 | else if ( mode == Icons ) | 285 | else if ( mode == Icons ) |
285 | { | 286 | { |
286 | _iconleaf = leaf; | 287 | _iconleaf = leaf; |
287 | _iconopened = opened; | 288 | _iconopened = opened; |
288 | _iconclosed = closed; | 289 | _iconclosed = closed; |
289 | } | 290 | } |
290 | else | 291 | else |
291 | { | 292 | { |
292 | qDebug( "OVersatileView::setDefaultPixmaps(): invalid mode" ); | 293 | odebug << "OVersatileView::setDefaultPixmaps(): invalid mode" << oendl; |
293 | } | 294 | } |
294 | } | 295 | } |
295 | 296 | ||
296 | QIconView* OVersatileView::iconView() const | 297 | QIconView* OVersatileView::iconView() const |
297 | { | 298 | { |
298 | return _iconview; | 299 | return _iconview; |
299 | } | 300 | } |
300 | 301 | ||
301 | OListView* OVersatileView::listView() const | 302 | OListView* OVersatileView::listView() const |
302 | { | 303 | { |
303 | return _listview; | 304 | return _listview; |
304 | } | 305 | } |
@@ -308,25 +309,25 @@ void OVersatileView::setViewMode( int mode ) | |||
308 | if ( mode == Tree ) | 309 | if ( mode == Tree ) |
309 | { | 310 | { |
310 | _viewmode = mode; | 311 | _viewmode = mode; |
311 | raiseWidget( _listview ); | 312 | raiseWidget( _listview ); |
312 | } | 313 | } |
313 | else if ( mode == Icons ) | 314 | else if ( mode == Icons ) |
314 | { | 315 | { |
315 | _viewmode = mode; | 316 | _viewmode = mode; |
316 | raiseWidget( _iconview ); | 317 | raiseWidget( _iconview ); |
317 | } | 318 | } |
318 | else | 319 | else |
319 | { | 320 | { |
320 | qDebug( "OVersatileView::setViewMode(): invalid mode" ); | 321 | odebug << "OVersatileView::setViewMode(): invalid mode" << oendl; |
321 | } | 322 | } |
322 | } | 323 | } |
323 | 324 | ||
324 | void OVersatileView::setIconViewMode() | 325 | void OVersatileView::setIconViewMode() |
325 | { | 326 | { |
326 | setViewMode( Icons ); | 327 | setViewMode( Icons ); |
327 | } | 328 | } |
328 | 329 | ||
329 | void OVersatileView::setTreeViewMode() | 330 | void OVersatileView::setTreeViewMode() |
330 | { | 331 | { |
331 | setViewMode( Tree ); | 332 | setViewMode( Tree ); |
332 | } | 333 | } |
@@ -334,39 +335,39 @@ void OVersatileView::setTreeViewMode() | |||
334 | bool OVersatileView::isValidViewMode( int mode ) const | 335 | bool OVersatileView::isValidViewMode( int mode ) const |
335 | { | 336 | { |
336 | switch ( _warningpolicy ) | 337 | switch ( _warningpolicy ) |
337 | { | 338 | { |
338 | case OVersatileView::None: | 339 | case OVersatileView::None: |
339 | { | 340 | { |
340 | return true; | 341 | return true; |
341 | } | 342 | } |
342 | case OVersatileView::Warn: | 343 | case OVersatileView::Warn: |
343 | { | 344 | { |
344 | if ( _viewmode != mode ) | 345 | if ( _viewmode != mode ) |
345 | { | 346 | { |
346 | qDebug( "OVersatileView::isValidViewMode(): Requested operation not valid in current mode." ); | 347 | odebug << "OVersatileView::isValidViewMode(): Requested operation not valid in current mode." << oendl; |
347 | return true; | 348 | return true; |
348 | } | 349 | } |
349 | } | 350 | } |
350 | case OVersatileView::WarnReturn: | 351 | case OVersatileView::WarnReturn: |
351 | { | 352 | { |
352 | if ( _viewmode != mode ) | 353 | if ( _viewmode != mode ) |
353 | { | 354 | { |
354 | qDebug( "OVersatileView::isValidViewMode(): Requested operation not valid in current mode." ); | 355 | odebug << "OVersatileView::isValidViewMode(): Requested operation not valid in current mode." << oendl; |
355 | return false; | 356 | return false; |
356 | } | 357 | } |
357 | } | 358 | } |
358 | default: | 359 | default: |
359 | { | 360 | { |
360 | qWarning( "OVersatileView::isValidViewMode(): Inconsistent object state!" ); | 361 | owarn << "OVersatileView::isValidViewMode(): Inconsistent object state!" << oendl; |
361 | return true; | 362 | return true; |
362 | } | 363 | } |
363 | } | 364 | } |
364 | } | 365 | } |
365 | void OVersatileView::setWarningPolicy( int policy ) const | 366 | void OVersatileView::setWarningPolicy( int policy ) const |
366 | { | 367 | { |
367 | _warningpolicy = policy; | 368 | _warningpolicy = policy; |
368 | } | 369 | } |
369 | bool OVersatileView::warningPolicy() const | 370 | bool OVersatileView::warningPolicy() const |
370 | { | 371 | { |
371 | return _warningpolicy; | 372 | return _warningpolicy; |
372 | } | 373 | } |
@@ -439,25 +440,25 @@ void OVersatileView::returnPressed( QIconViewItem * item ) | |||
439 | void OVersatileView::onItem( QListViewItem * item ) | 440 | void OVersatileView::onItem( QListViewItem * item ) |
440 | { | 441 | { |
441 | emit( onItem( static_cast<OVersatileViewItem*>( item ) ) ); | 442 | emit( onItem( static_cast<OVersatileViewItem*>( item ) ) ); |
442 | } | 443 | } |
443 | 444 | ||
444 | void OVersatileView::onItem( QIconViewItem * item ) | 445 | void OVersatileView::onItem( QIconViewItem * item ) |
445 | { | 446 | { |
446 | emit( onItem( static_cast<OVersatileViewItem*>( item ) ) ); | 447 | emit( onItem( static_cast<OVersatileViewItem*>( item ) ) ); |
447 | } | 448 | } |
448 | 449 | ||
449 | void OVersatileView::expanded( QListViewItem *item ) // QListView | 450 | void OVersatileView::expanded( QListViewItem *item ) // QListView |
450 | { | 451 | { |
451 | //qDebug( "OVersatileView::expanded(): opening tree..." ); | 452 | //odebug << "OVersatileView::expanded(): opening tree..." << oendl; |
452 | if ( !_treeopened.isNull() ) | 453 | if ( !_treeopened.isNull() ) |
453 | item->setPixmap( 0, _treeopened ); | 454 | item->setPixmap( 0, _treeopened ); |
454 | emit( expanded( static_cast<OVersatileViewItem*>( item ) ) ); | 455 | emit( expanded( static_cast<OVersatileViewItem*>( item ) ) ); |
455 | } | 456 | } |
456 | void OVersatileView::collapsed( QListViewItem *item ) // QListView | 457 | void OVersatileView::collapsed( QListViewItem *item ) // QListView |
457 | { | 458 | { |
458 | if ( !_treeclosed.isNull() ) | 459 | if ( !_treeclosed.isNull() ) |
459 | item->setPixmap( 0, _treeclosed ); | 460 | item->setPixmap( 0, _treeclosed ); |
460 | emit( collapsed( static_cast<OVersatileViewItem*>( item ) ) ); | 461 | emit( collapsed( static_cast<OVersatileViewItem*>( item ) ) ); |
461 | } | 462 | } |
462 | 463 | ||
463 | //=============================================================================================// | 464 | //=============================================================================================// |