author | drw <drw> | 2005-04-14 18:29:44 (UTC) |
---|---|---|
committer | drw <drw> | 2005-04-14 18:29:44 (UTC) |
commit | 7a3b813cc3bfbb2f7c31f347c35405851e82aecf (patch) (unidiff) | |
tree | b9d384b6d33e396a0219386b4bf695b092bb606d /library/qpestyle.cpp | |
parent | 5f600ec21480d1d040203407a1d2446781702230 (diff) | |
download | opie-7a3b813cc3bfbb2f7c31f347c35405851e82aecf.zip opie-7a3b813cc3bfbb2f7c31f347c35405851e82aecf.tar.gz opie-7a3b813cc3bfbb2f7c31f347c35405851e82aecf.tar.bz2 |
Fix icon sizing for light and qpe styles
-rw-r--r-- | library/qpestyle.cpp | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/library/qpestyle.cpp b/library/qpestyle.cpp index 0566f6b..9503e02 100644 --- a/library/qpestyle.cpp +++ b/library/qpestyle.cpp | |||
@@ -654,538 +654,542 @@ void QPEStyle::scrollBarMetrics( const QScrollBar* sb, int &sliderMin, int &slid | |||
654 | sliderLength = maxLength; | 654 | sliderLength = maxLength; |
655 | } else { | 655 | } else { |
656 | sliderLength = (sb->pageStep()*maxLength)/ | 656 | sliderLength = (sb->pageStep()*maxLength)/ |
657 | (sb->maxValue()-sb->minValue()+sb->pageStep()); | 657 | (sb->maxValue()-sb->minValue()+sb->pageStep()); |
658 | uint range = sb->maxValue()-sb->minValue(); | 658 | uint range = sb->maxValue()-sb->minValue(); |
659 | if ( sliderLength < SLIDER_MIN || range > INT_MAX/2 ) | 659 | if ( sliderLength < SLIDER_MIN || range > INT_MAX/2 ) |
660 | sliderLength = SLIDER_MIN; | 660 | sliderLength = SLIDER_MIN; |
661 | if ( sliderLength > maxLength ) | 661 | if ( sliderLength > maxLength ) |
662 | sliderLength = maxLength; | 662 | sliderLength = maxLength; |
663 | } | 663 | } |
664 | 664 | ||
665 | sliderMax = sliderMin + maxLength - sliderLength; | 665 | sliderMax = sliderMin + maxLength - sliderLength; |
666 | } | 666 | } |
667 | 667 | ||
668 | /*!\reimp | 668 | /*!\reimp |
669 | */ | 669 | */ |
670 | QStyle::ScrollControl QPEStyle::scrollBarPointOver( const QScrollBar* sb, int sliderStart, const QPoint& p ) | 670 | QStyle::ScrollControl QPEStyle::scrollBarPointOver( const QScrollBar* sb, int sliderStart, const QPoint& p ) |
671 | { | 671 | { |
672 | if ( !sb->rect().contains( p ) ) | 672 | if ( !sb->rect().contains( p ) ) |
673 | return NoScroll; | 673 | return NoScroll; |
674 | int sliderMin, sliderMax, sliderLength, buttonDim, pos; | 674 | int sliderMin, sliderMax, sliderLength, buttonDim, pos; |
675 | scrollBarMetrics( sb, sliderMin, sliderMax, sliderLength, buttonDim ); | 675 | scrollBarMetrics( sb, sliderMin, sliderMax, sliderLength, buttonDim ); |
676 | 676 | ||
677 | if (sb->orientation() == QScrollBar::Horizontal) | 677 | if (sb->orientation() == QScrollBar::Horizontal) |
678 | pos = p.x(); | 678 | pos = p.x(); |
679 | else | 679 | else |
680 | pos = p.y(); | 680 | pos = p.y(); |
681 | 681 | ||
682 | if (pos < sliderStart) | 682 | if (pos < sliderStart) |
683 | return SubPage; | 683 | return SubPage; |
684 | if (pos < sliderStart + sliderLength) | 684 | if (pos < sliderStart + sliderLength) |
685 | return Slider; | 685 | return Slider; |
686 | if (pos < sliderMax + sliderLength) | 686 | if (pos < sliderMax + sliderLength) |
687 | return AddPage; | 687 | return AddPage; |
688 | if (pos < sliderMax + sliderLength + buttonDim) | 688 | if (pos < sliderMax + sliderLength + buttonDim) |
689 | return SubLine; | 689 | return SubLine; |
690 | return AddLine; | 690 | return AddLine; |
691 | } | 691 | } |
692 | 692 | ||
693 | /*! \reimp */ | 693 | /*! \reimp */ |
694 | 694 | ||
695 | void QPEStyle::drawScrollBarControls( QPainter* p, const QScrollBar* sb, int sliderStart, uint controls, uint activeControl ) | 695 | void QPEStyle::drawScrollBarControls( QPainter* p, const QScrollBar* sb, int sliderStart, uint controls, uint activeControl ) |
696 | { | 696 | { |
697 | #define ADD_LINE_ACTIVE ( activeControl == AddLine ) | 697 | #define ADD_LINE_ACTIVE ( activeControl == AddLine ) |
698 | #define SUB_LINE_ACTIVE ( activeControl == SubLine ) | 698 | #define SUB_LINE_ACTIVE ( activeControl == SubLine ) |
699 | QColorGroup g = sb->colorGroup(); | 699 | QColorGroup g = sb->colorGroup(); |
700 | 700 | ||
701 | int sliderMin, sliderMax, sliderLength, buttonDim; | 701 | int sliderMin, sliderMax, sliderLength, buttonDim; |
702 | scrollBarMetrics( sb, sliderMin, sliderMax, sliderLength, buttonDim ); | 702 | scrollBarMetrics( sb, sliderMin, sliderMax, sliderLength, buttonDim ); |
703 | 703 | ||
704 | if ( controls == (AddLine | SubLine | AddPage | SubPage | Slider | First | Last ) ) | 704 | if ( controls == (AddLine | SubLine | AddPage | SubPage | Slider | First | Last ) ) |
705 | p->fillRect( 0, 0, sb->width(), sb->height(), g.brush( QColorGroup::Mid )); | 705 | p->fillRect( 0, 0, sb->width(), sb->height(), g.brush( QColorGroup::Mid )); |
706 | 706 | ||
707 | if (sliderStart > sliderMax) { // sanity check | 707 | if (sliderStart > sliderMax) { // sanity check |
708 | sliderStart = sliderMax; | 708 | sliderStart = sliderMax; |
709 | } | 709 | } |
710 | 710 | ||
711 | int dimB = buttonDim; | 711 | int dimB = buttonDim; |
712 | QRect addB; | 712 | QRect addB; |
713 | QRect subB; | 713 | QRect subB; |
714 | QRect addPageR; | 714 | QRect addPageR; |
715 | QRect subPageR; | 715 | QRect subPageR; |
716 | QRect sliderR; | 716 | QRect sliderR; |
717 | int addX, addY, subX, subY; | 717 | int addX, addY, subX, subY; |
718 | int length = HORIZONTAL ? sb->width() : sb->height(); | 718 | int length = HORIZONTAL ? sb->width() : sb->height(); |
719 | int extent = HORIZONTAL ? sb->height() : sb->width(); | 719 | int extent = HORIZONTAL ? sb->height() : sb->width(); |
720 | 720 | ||
721 | if ( HORIZONTAL ) { | 721 | if ( HORIZONTAL ) { |
722 | subY = addY = ( extent - dimB ) / 2; | 722 | subY = addY = ( extent - dimB ) / 2; |
723 | subX = length - dimB - dimB; | 723 | subX = length - dimB - dimB; |
724 | addX = length - dimB; | 724 | addX = length - dimB; |
725 | } else { | 725 | } else { |
726 | subX = addX = ( extent - dimB ) / 2; | 726 | subX = addX = ( extent - dimB ) / 2; |
727 | subY = length - dimB - dimB; | 727 | subY = length - dimB - dimB; |
728 | addY = length - dimB; | 728 | addY = length - dimB; |
729 | } | 729 | } |
730 | 730 | ||
731 | int sliderEnd = sliderStart + sliderLength; | 731 | int sliderEnd = sliderStart + sliderLength; |
732 | int sliderW = extent; | 732 | int sliderW = extent; |
733 | if ( HORIZONTAL ) { | 733 | if ( HORIZONTAL ) { |
734 | subB.setRect( subX,subY+1,dimB,dimB-1 ); | 734 | subB.setRect( subX,subY+1,dimB,dimB-1 ); |
735 | addB.setRect( addX,addY+1,dimB,dimB-1 ); | 735 | addB.setRect( addX,addY+1,dimB,dimB-1 ); |
736 | 736 | ||
737 | subPageR.setRect( 0, 0, | 737 | subPageR.setRect( 0, 0, |
738 | sliderStart+1, sliderW ); | 738 | sliderStart+1, sliderW ); |
739 | addPageR.setRect( sliderEnd-1, 0, subX - sliderEnd+1, sliderW ); | 739 | addPageR.setRect( sliderEnd-1, 0, subX - sliderEnd+1, sliderW ); |
740 | sliderR .setRect( sliderStart, 1, sliderLength, sliderW-1 ); | 740 | sliderR .setRect( sliderStart, 1, sliderLength, sliderW-1 ); |
741 | 741 | ||
742 | } else { | 742 | } else { |
743 | subB.setRect( subX+1,subY,dimB-1,dimB ); | 743 | subB.setRect( subX+1,subY,dimB-1,dimB ); |
744 | addB.setRect( addX+1,addY,dimB-1,dimB ); | 744 | addB.setRect( addX+1,addY,dimB-1,dimB ); |
745 | 745 | ||
746 | subPageR.setRect( 0, 0, sliderW, | 746 | subPageR.setRect( 0, 0, sliderW, |
747 | sliderStart+1 ); | 747 | sliderStart+1 ); |
748 | addPageR.setRect( 0, sliderEnd-1, sliderW, subY - sliderEnd+1 ); | 748 | addPageR.setRect( 0, sliderEnd-1, sliderW, subY - sliderEnd+1 ); |
749 | sliderR .setRect( 1, sliderStart, sliderW-1, sliderLength ); | 749 | sliderR .setRect( 1, sliderStart, sliderW-1, sliderLength ); |
750 | } | 750 | } |
751 | 751 | ||
752 | bool maxedOut = (sb->maxValue() == sb->minValue()); | 752 | bool maxedOut = (sb->maxValue() == sb->minValue()); |
753 | if ( controls & AddLine ) { | 753 | if ( controls & AddLine ) { |
754 | drawBevelButton( p, addB.x(), addB.y(), | 754 | drawBevelButton( p, addB.x(), addB.y(), |
755 | addB.width(), addB.height(), g, | 755 | addB.width(), addB.height(), g, |
756 | ADD_LINE_ACTIVE); | 756 | ADD_LINE_ACTIVE); |
757 | p->setPen(g.shadow()); | 757 | p->setPen(g.shadow()); |
758 | drawArrow( p, VERTICAL ? DownArrow : RightArrow, | 758 | drawArrow( p, VERTICAL ? DownArrow : RightArrow, |
759 | FALSE, addB.x()+2, addB.y()+2, | 759 | FALSE, addB.x()+2, addB.y()+2, |
760 | addB.width()-4, addB.height()-4, g, !maxedOut, | 760 | addB.width()-4, addB.height()-4, g, !maxedOut, |
761 | &g.brush( QColorGroup::Button )); | 761 | &g.brush( QColorGroup::Button )); |
762 | } | 762 | } |
763 | if ( controls & SubLine ) { | 763 | if ( controls & SubLine ) { |
764 | drawBevelButton( p, subB.x(), subB.y(), | 764 | drawBevelButton( p, subB.x(), subB.y(), |
765 | subB.width(), subB.height(), g, | 765 | subB.width(), subB.height(), g, |
766 | SUB_LINE_ACTIVE ); | 766 | SUB_LINE_ACTIVE ); |
767 | p->setPen(g.shadow()); | 767 | p->setPen(g.shadow()); |
768 | drawArrow( p, VERTICAL ? UpArrow : LeftArrow, | 768 | drawArrow( p, VERTICAL ? UpArrow : LeftArrow, |
769 | FALSE, subB.x()+2, subB.y()+2, | 769 | FALSE, subB.x()+2, subB.y()+2, |
770 | subB.width()-4, subB.height()-4, g, !maxedOut, | 770 | subB.width()-4, subB.height()-4, g, !maxedOut, |
771 | &g.brush( QColorGroup::Button )); | 771 | &g.brush( QColorGroup::Button )); |
772 | } | 772 | } |
773 | 773 | ||
774 | 774 | ||
775 | if ( controls & SubPage ) | 775 | if ( controls & SubPage ) |
776 | p->fillRect( subPageR.x(), subPageR.y(), subPageR.width(), | 776 | p->fillRect( subPageR.x(), subPageR.y(), subPageR.width(), |
777 | subPageR.height(), g.brush( QColorGroup::Mid )); | 777 | subPageR.height(), g.brush( QColorGroup::Mid )); |
778 | if ( controls & AddPage ) | 778 | if ( controls & AddPage ) |
779 | p->fillRect( addPageR.x(), addPageR.y(), addPageR.width(), | 779 | p->fillRect( addPageR.x(), addPageR.y(), addPageR.width(), |
780 | addPageR.height(), g.brush( QColorGroup::Mid )); | 780 | addPageR.height(), g.brush( QColorGroup::Mid )); |
781 | if ( controls & Slider ) { | 781 | if ( controls & Slider ) { |
782 | QPoint bo = p->brushOrigin(); | 782 | QPoint bo = p->brushOrigin(); |
783 | p->setBrushOrigin(sliderR.topLeft()); | 783 | p->setBrushOrigin(sliderR.topLeft()); |
784 | drawBevelButton( p, sliderR.x(), sliderR.y(), | 784 | drawBevelButton( p, sliderR.x(), sliderR.y(), |
785 | sliderR.width(), sliderR.height(), g, | 785 | sliderR.width(), sliderR.height(), g, |
786 | FALSE, &g.brush( QColorGroup::Button ) ); | 786 | FALSE, &g.brush( QColorGroup::Button ) ); |
787 | p->setBrushOrigin(bo); | 787 | p->setBrushOrigin(bo); |
788 | drawRiffles( p, sliderR.x(), sliderR.y(), | 788 | drawRiffles( p, sliderR.x(), sliderR.y(), |
789 | sliderR.width(), sliderR.height(), g, HORIZONTAL ); | 789 | sliderR.width(), sliderR.height(), g, HORIZONTAL ); |
790 | } | 790 | } |
791 | 791 | ||
792 | // ### perhaps this should not be able to accept focus if maxedOut? | 792 | // ### perhaps this should not be able to accept focus if maxedOut? |
793 | if ( sb->hasFocus() && (controls & Slider) ) | 793 | if ( sb->hasFocus() && (controls & Slider) ) |
794 | p->drawWinFocusRect( sliderR.x()+2, sliderR.y()+2, | 794 | p->drawWinFocusRect( sliderR.x()+2, sliderR.y()+2, |
795 | sliderR.width()-5, sliderR.height()-5, | 795 | sliderR.width()-5, sliderR.height()-5, |
796 | sb->backgroundColor() ); | 796 | sb->backgroundColor() ); |
797 | 797 | ||
798 | } | 798 | } |
799 | 799 | ||
800 | void QPEStyle::drawRiffles( QPainter* p, int x, int y, int w, int h, | 800 | void QPEStyle::drawRiffles( QPainter* p, int x, int y, int w, int h, |
801 | const QColorGroup &g, bool horizontal ) | 801 | const QColorGroup &g, bool horizontal ) |
802 | { | 802 | { |
803 | if (!horizontal) { | 803 | if (!horizontal) { |
804 | if (h > 20) { | 804 | if (h > 20) { |
805 | y += (h-20)/2 ; | 805 | y += (h-20)/2 ; |
806 | h = 20; | 806 | h = 20; |
807 | } | 807 | } |
808 | if (h > 12) { | 808 | if (h > 12) { |
809 | int n = 3; | 809 | int n = 3; |
810 | int my = y+h/2-4; | 810 | int my = y+h/2-4; |
811 | int i ; | 811 | int i ; |
812 | p->setPen(g.light()); | 812 | p->setPen(g.light()); |
813 | for (i=0; i<n; i++) { | 813 | for (i=0; i<n; i++) { |
814 | p->drawLine(x+2, my+3*i, x+w-4, my+3*i); | 814 | p->drawLine(x+2, my+3*i, x+w-4, my+3*i); |
815 | } | 815 | } |
816 | p->setPen(g.dark()); | 816 | p->setPen(g.dark()); |
817 | my++; | 817 | my++; |
818 | for (i=0; i<n; i++) { | 818 | for (i=0; i<n; i++) { |
819 | p->drawLine(x+2, my+3*i, x+w-4, my+3*i); | 819 | p->drawLine(x+2, my+3*i, x+w-4, my+3*i); |
820 | } | 820 | } |
821 | } | 821 | } |
822 | } | 822 | } |
823 | else { | 823 | else { |
824 | if (w > 20) { | 824 | if (w > 20) { |
825 | x += (w-20)/2 ; | 825 | x += (w-20)/2 ; |
826 | w = 20; | 826 | w = 20; |
827 | } | 827 | } |
828 | if (w > 12) { | 828 | if (w > 12) { |
829 | int n = 3; | 829 | int n = 3; |
830 | int mx = x+w/2-4; | 830 | int mx = x+w/2-4; |
831 | int i ; | 831 | int i ; |
832 | p->setPen(g.light()); | 832 | p->setPen(g.light()); |
833 | for (i=0; i<n; i++) { | 833 | for (i=0; i<n; i++) { |
834 | p->drawLine(mx+3*i, y+2, mx + 3*i, y+h-4); | 834 | p->drawLine(mx+3*i, y+2, mx + 3*i, y+h-4); |
835 | } | 835 | } |
836 | p->setPen(g.dark()); | 836 | p->setPen(g.dark()); |
837 | mx++; | 837 | mx++; |
838 | for (i=0; i<n; i++) { | 838 | for (i=0; i<n; i++) { |
839 | p->drawLine(mx+3*i, y+2, mx + 3*i, y+h-4); | 839 | p->drawLine(mx+3*i, y+2, mx + 3*i, y+h-4); |
840 | } | 840 | } |
841 | } | 841 | } |
842 | } | 842 | } |
843 | } | 843 | } |
844 | 844 | ||
845 | int QPEStyle::sliderLength() const | 845 | int QPEStyle::sliderLength() const |
846 | { | 846 | { |
847 | return 12; | 847 | return 12; |
848 | } | 848 | } |
849 | 849 | ||
850 | void QPEStyle::drawSlider( QPainter *p, int x, int y, int w, int h, | 850 | void QPEStyle::drawSlider( QPainter *p, int x, int y, int w, int h, |
851 | const QColorGroup &g, Orientation o, bool tickAbove, bool tickBelow ) | 851 | const QColorGroup &g, Orientation o, bool tickAbove, bool tickBelow ) |
852 | { | 852 | { |
853 | int a = tickAbove ? 3 : 0; | 853 | int a = tickAbove ? 3 : 0; |
854 | int b = tickBelow ? 3 : 0; | 854 | int b = tickBelow ? 3 : 0; |
855 | 855 | ||
856 | if ( o == Horizontal ) { | 856 | if ( o == Horizontal ) { |
857 | drawBevelButton( p, x, y+a, w, h-a-b, g, FALSE, &g.brush( QColorGroup::Button ) ); | 857 | drawBevelButton( p, x, y+a, w, h-a-b, g, FALSE, &g.brush( QColorGroup::Button ) ); |
858 | int xp = x + w/2; | 858 | int xp = x + w/2; |
859 | qDrawShadeLine( p, xp, y+a+2, xp, y+h-b-3, g ); | 859 | qDrawShadeLine( p, xp, y+a+2, xp, y+h-b-3, g ); |
860 | } else { | 860 | } else { |
861 | drawBevelButton( p, x+a, y, w-a-b, h, g, FALSE, &g.brush( QColorGroup::Button ) ); | 861 | drawBevelButton( p, x+a, y, w-a-b, h, g, FALSE, &g.brush( QColorGroup::Button ) ); |
862 | int yp = y + h/2; | 862 | int yp = y + h/2; |
863 | qDrawShadeLine( p, x+a+2, yp, x+w-b-3, yp, g ); | 863 | qDrawShadeLine( p, x+a+2, yp, x+w-b-3, yp, g ); |
864 | } | 864 | } |
865 | } | 865 | } |
866 | 866 | ||
867 | void QPEStyle::drawSliderMask ( QPainter * p, int x, int y, int w, int h, | 867 | void QPEStyle::drawSliderMask ( QPainter * p, int x, int y, int w, int h, |
868 | Orientation o, bool tickAbove, bool tickBelow ) | 868 | Orientation o, bool tickAbove, bool tickBelow ) |
869 | { | 869 | { |
870 | int a = tickAbove ? 3 : 0; | 870 | int a = tickAbove ? 3 : 0; |
871 | int b = tickBelow ? 3 : 0; | 871 | int b = tickBelow ? 3 : 0; |
872 | if ( o == Horizontal ) | 872 | if ( o == Horizontal ) |
873 | p->fillRect( x, y+a, w, h-a-b, color1 ); | 873 | p->fillRect( x, y+a, w, h-a-b, color1 ); |
874 | else | 874 | else |
875 | p->fillRect( x+a, y, w-a-b, h, color1 ); | 875 | p->fillRect( x+a, y, w-a-b, h, color1 ); |
876 | } | 876 | } |
877 | 877 | ||
878 | /*!\reimp | 878 | /*!\reimp |
879 | */ | 879 | */ |
880 | void QPEStyle::drawSliderGrooveMask( QPainter *p, | 880 | void QPEStyle::drawSliderGrooveMask( QPainter *p, |
881 | int x, int y, int w, int h, | 881 | int x, int y, int w, int h, |
882 | const QColorGroup& , QCOORD c, | 882 | const QColorGroup& , QCOORD c, |
883 | Orientation orient ) | 883 | Orientation orient ) |
884 | { | 884 | { |
885 | if ( orient == Horizontal ) | 885 | if ( orient == Horizontal ) |
886 | p->fillRect( x, y + c - 2, w, 4, color1 ); | 886 | p->fillRect( x, y + c - 2, w, 4, color1 ); |
887 | else | 887 | else |
888 | p->fillRect( x + c - 2, y, 4, h, color1 ); | 888 | p->fillRect( x + c - 2, y, 4, h, color1 ); |
889 | } | 889 | } |
890 | 890 | ||
891 | void QPEStyle::drawTab( QPainter *p, const QTabBar *tb, QTab *t, bool selected ) | 891 | void QPEStyle::drawTab( QPainter *p, const QTabBar *tb, QTab *t, bool selected ) |
892 | { | 892 | { |
893 | QRect r( t->rect() ); | 893 | QRect r( t->rect() ); |
894 | if ( tb->shape() == QTabBar::RoundedAbove ) { | 894 | if ( tb->shape() == QTabBar::RoundedAbove ) { |
895 | p->setPen( tb->colorGroup().light() ); | 895 | p->setPen( tb->colorGroup().light() ); |
896 | p->drawLine( r.left(), r.bottom(), r.right(), r.bottom() ); | 896 | p->drawLine( r.left(), r.bottom(), r.right(), r.bottom() ); |
897 | if ( r.left() == 0 ) | 897 | if ( r.left() == 0 ) |
898 | p->drawPoint( tb->rect().bottomLeft() ); | 898 | p->drawPoint( tb->rect().bottomLeft() ); |
899 | else { | 899 | else { |
900 | p->setPen( tb->colorGroup().light() ); | 900 | p->setPen( tb->colorGroup().light() ); |
901 | p->drawLine( r.left(), r.bottom(), r.right(), r.bottom() ); | 901 | p->drawLine( r.left(), r.bottom(), r.right(), r.bottom() ); |
902 | } | 902 | } |
903 | 903 | ||
904 | if ( selected ) { | 904 | if ( selected ) { |
905 | p->setPen( tb->colorGroup().background() ); | 905 | p->setPen( tb->colorGroup().background() ); |
906 | p->drawLine( r.left()+2, r.top()+1, r.right()-2, r.top()+1 ); | 906 | p->drawLine( r.left()+2, r.top()+1, r.right()-2, r.top()+1 ); |
907 | p->fillRect( QRect( r.left()+1, r.top()+2, r.width()-2, r.height()-2), | 907 | p->fillRect( QRect( r.left()+1, r.top()+2, r.width()-2, r.height()-2), |
908 | tb->colorGroup().brush( QColorGroup::Background )); | 908 | tb->colorGroup().brush( QColorGroup::Background )); |
909 | } else { | 909 | } else { |
910 | r.setRect( r.left() + 2, r.top() + 2, | 910 | r.setRect( r.left() + 2, r.top() + 2, |
911 | r.width() - 4, r.height() - 2 ); | 911 | r.width() - 4, r.height() - 2 ); |
912 | p->setPen( tb->colorGroup().button() ); | 912 | p->setPen( tb->colorGroup().button() ); |
913 | p->drawLine( r.left()+2, r.top()+1, r.right()-2, r.top()+1 ); | 913 | p->drawLine( r.left()+2, r.top()+1, r.right()-2, r.top()+1 ); |
914 | p->fillRect( QRect( r.left()+1, r.top()+2, r.width()-2, r.height()-3), | 914 | p->fillRect( QRect( r.left()+1, r.top()+2, r.width()-2, r.height()-3), |
915 | tb->colorGroup().brush( QColorGroup::Button )); | 915 | tb->colorGroup().brush( QColorGroup::Button )); |
916 | 916 | ||
917 | //do shading; will not work for pixmap brushes | 917 | //do shading; will not work for pixmap brushes |
918 | QColor bg = tb->colorGroup().button(); | 918 | QColor bg = tb->colorGroup().button(); |
919 | // int h,s,v; | 919 | // int h,s,v; |
920 | // bg.hsv( &h, &s, &v ); | 920 | // bg.hsv( &h, &s, &v ); |
921 | int n = r.height()/2; | 921 | int n = r.height()/2; |
922 | int dark = 100; | 922 | int dark = 100; |
923 | for ( int i = 1; i < n; i++ ) { | 923 | for ( int i = 1; i < n; i++ ) { |
924 | dark = (dark * (100+(i*15)/n) )/100; | 924 | dark = (dark * (100+(i*15)/n) )/100; |
925 | p->setPen( bg.dark( dark ) ); | 925 | p->setPen( bg.dark( dark ) ); |
926 | int y = r.bottom()-n+i; | 926 | int y = r.bottom()-n+i; |
927 | int x1 = r.left()+1; | 927 | int x1 = r.left()+1; |
928 | int x2 = r.right()-1; | 928 | int x2 = r.right()-1; |
929 | p->drawLine( x1, y, x2, y ); | 929 | p->drawLine( x1, y, x2, y ); |
930 | } | 930 | } |
931 | } | 931 | } |
932 | 932 | ||
933 | p->setPen( tb->colorGroup().light() ); | 933 | p->setPen( tb->colorGroup().light() ); |
934 | p->drawLine( r.left(), r.bottom()-1, r.left(), r.top() + 2 ); | 934 | p->drawLine( r.left(), r.bottom()-1, r.left(), r.top() + 2 ); |
935 | p->drawPoint( r.left()+1, r.top() + 1 ); | 935 | p->drawPoint( r.left()+1, r.top() + 1 ); |
936 | p->drawLine( r.left()+2, r.top(), | 936 | p->drawLine( r.left()+2, r.top(), |
937 | r.right() - 2, r.top() ); | 937 | r.right() - 2, r.top() ); |
938 | 938 | ||
939 | p->setPen( tb->colorGroup().dark() ); | 939 | p->setPen( tb->colorGroup().dark() ); |
940 | p->drawPoint( r.right() - 1, r.top() + 1 ); | 940 | p->drawPoint( r.right() - 1, r.top() + 1 ); |
941 | p->drawLine( r.right(), r.top() + 2, r.right(), r.bottom() - 1); | 941 | p->drawLine( r.right(), r.top() + 2, r.right(), r.bottom() - 1); |
942 | } else if ( tb->shape() == QTabBar::RoundedBelow ) { | 942 | } else if ( tb->shape() == QTabBar::RoundedBelow ) { |
943 | if ( selected ) { | 943 | if ( selected ) { |
944 | p->setPen( tb->colorGroup().background() ); | 944 | p->setPen( tb->colorGroup().background() ); |
945 | p->drawLine( r.left()+2, r.bottom()-1, r.right()-2, r.bottom()-1 ); | 945 | p->drawLine( r.left()+2, r.bottom()-1, r.right()-2, r.bottom()-1 ); |
946 | p->fillRect( QRect( r.left()+1, r.top(), r.width()-2, r.height()-2), | 946 | p->fillRect( QRect( r.left()+1, r.top(), r.width()-2, r.height()-2), |
947 | tb->palette().normal().brush( QColorGroup::Background )); | 947 | tb->palette().normal().brush( QColorGroup::Background )); |
948 | } else { | 948 | } else { |
949 | p->setPen( tb->colorGroup().dark() ); | 949 | p->setPen( tb->colorGroup().dark() ); |
950 | p->drawLine( r.left(), r.top(), | 950 | p->drawLine( r.left(), r.top(), |
951 | r.right(), r.top() ); | 951 | r.right(), r.top() ); |
952 | r.setRect( r.left() + 2, r.top(), | 952 | r.setRect( r.left() + 2, r.top(), |
953 | r.width() - 4, r.height() - 2 ); | 953 | r.width() - 4, r.height() - 2 ); |
954 | p->setPen( tb->colorGroup().button() ); | 954 | p->setPen( tb->colorGroup().button() ); |
955 | p->drawLine( r.left()+2, r.bottom()-1, r.right()-2, r.bottom()-1 ); | 955 | p->drawLine( r.left()+2, r.bottom()-1, r.right()-2, r.bottom()-1 ); |
956 | p->fillRect( QRect( r.left()+1, r.top()+1, r.width()-2, r.height()-3), | 956 | p->fillRect( QRect( r.left()+1, r.top()+1, r.width()-2, r.height()-3), |
957 | tb->palette().normal().brush( QColorGroup::Button )); | 957 | tb->palette().normal().brush( QColorGroup::Button )); |
958 | } | 958 | } |
959 | 959 | ||
960 | p->setPen( tb->colorGroup().dark() ); | 960 | p->setPen( tb->colorGroup().dark() ); |
961 | p->drawLine( r.right(), r.top(), | 961 | p->drawLine( r.right(), r.top(), |
962 | r.right(), r.bottom() - 2 ); | 962 | r.right(), r.bottom() - 2 ); |
963 | p->drawPoint( r.right() - 1, r.bottom() - 1 ); | 963 | p->drawPoint( r.right() - 1, r.bottom() - 1 ); |
964 | p->drawLine( r.right() - 2, r.bottom(), | 964 | p->drawLine( r.right() - 2, r.bottom(), |
965 | r.left() + 2, r.bottom() ); | 965 | r.left() + 2, r.bottom() ); |
966 | 966 | ||
967 | p->setPen( tb->colorGroup().light() ); | 967 | p->setPen( tb->colorGroup().light() ); |
968 | p->drawLine( r.left(), r.top()+1, | 968 | p->drawLine( r.left(), r.top()+1, |
969 | r.left(), r.bottom() - 2 ); | 969 | r.left(), r.bottom() - 2 ); |
970 | p->drawPoint( r.left() + 1, r.bottom() - 1 ); | 970 | p->drawPoint( r.left() + 1, r.bottom() - 1 ); |
971 | if ( r.left() == 0 ) | 971 | if ( r.left() == 0 ) |
972 | p->drawPoint( tb->rect().topLeft() ); | 972 | p->drawPoint( tb->rect().topLeft() ); |
973 | 973 | ||
974 | } else { | 974 | } else { |
975 | QCommonStyle::drawTab( p, tb, t, selected ); | 975 | QCommonStyle::drawTab( p, tb, t, selected ); |
976 | } | 976 | } |
977 | } | 977 | } |
978 | 978 | ||
979 | static const int motifItemFrame = 0;// menu item frame width | 979 | static const int motifItemFrame = 0;// menu item frame width |
980 | static const int motifSepHeight = 2;// separator item height | 980 | static const int motifSepHeight = 2;// separator item height |
981 | static const int motifItemHMargin = 1;// menu item hor text margin | 981 | static const int motifItemHMargin = 1;// menu item hor text margin |
982 | static const int motifItemVMargin = 2;// menu item ver text margin | 982 | static const int motifItemVMargin = 2;// menu item ver text margin |
983 | static const int motifArrowHMargin = 0;// arrow horizontal margin | 983 | static const int motifArrowHMargin = 0;// arrow horizontal margin |
984 | static const int motifTabSpacing = 12;// space between text and tab | 984 | static const int motifTabSpacing = 12;// space between text and tab |
985 | static const int motifCheckMarkHMargin = 1;// horiz. margins of check mark | 985 | static const int motifCheckMarkHMargin = 1;// horiz. margins of check mark |
986 | static const int windowsRightBorder= 8; // right border on windows | 986 | static const int windowsRightBorder= 8; // right border on windows |
987 | static const int windowsCheckMarkWidth = 2; // checkmarks width on windows | 987 | static const int windowsCheckMarkWidth = 2; // checkmarks width on windows |
988 | 988 | ||
989 | /*! \reimp | 989 | /*! \reimp |
990 | */ | 990 | */ |
991 | int QPEStyle::extraPopupMenuItemWidth( bool checkable, int maxpmw, QMenuItem* mi, const QFontMetrics& /*fm*/ ) | 991 | int QPEStyle::extraPopupMenuItemWidth( bool checkable, int maxpmw, QMenuItem* mi, const QFontMetrics& /*fm*/ ) |
992 | { | 992 | { |
993 | #ifndef QT_NO_MENUDATA | 993 | #ifndef QT_NO_MENUDATA |
994 | int w = 2*motifItemHMargin + 2*motifItemFrame; // a little bit of border can never harm | 994 | int w = 2*motifItemHMargin + 2*motifItemFrame; // a little bit of border can never harm |
995 | 995 | ||
996 | if ( mi->isSeparator() ) | 996 | if ( mi->isSeparator() ) |
997 | return 10; // arbitrary | 997 | return 10; // arbitrary |
998 | else if ( mi->pixmap() ) | 998 | else if ( mi->pixmap() ) |
999 | w += mi->pixmap()->width();// pixmap only | 999 | w += mi->pixmap()->width();// pixmap only |
1000 | 1000 | ||
1001 | if ( !mi->text().isNull() ) { | 1001 | if ( !mi->text().isNull() ) { |
1002 | if ( mi->text().find('\t') >= 0 )// string contains tab | 1002 | if ( mi->text().find('\t') >= 0 )// string contains tab |
1003 | w += motifTabSpacing; | 1003 | w += motifTabSpacing; |
1004 | } | 1004 | } |
1005 | 1005 | ||
1006 | if ( maxpmw ) { // we have iconsets | 1006 | if ( maxpmw ) { // we have iconsets |
1007 | w += maxpmw; | 1007 | w += maxpmw; |
1008 | w += 6; // add a little extra border around the iconset | 1008 | w += 6; // add a little extra border around the iconset |
1009 | } | 1009 | } |
1010 | 1010 | ||
1011 | if ( checkable && maxpmw < windowsCheckMarkWidth ) { | 1011 | if ( checkable && maxpmw < windowsCheckMarkWidth ) { |
1012 | w += windowsCheckMarkWidth - maxpmw; // space for the checkmarks | 1012 | w += windowsCheckMarkWidth - maxpmw; // space for the checkmarks |
1013 | } | 1013 | } |
1014 | 1014 | ||
1015 | if ( maxpmw > 0 || checkable ) // we have a check-column ( iconsets or checkmarks) | 1015 | if ( maxpmw > 0 || checkable ) // we have a check-column ( iconsets or checkmarks) |
1016 | w += motifCheckMarkHMargin; // add space to separate the columns | 1016 | w += motifCheckMarkHMargin; // add space to separate the columns |
1017 | 1017 | ||
1018 | w += windowsRightBorder; // windows has a strange wide border on the right side | 1018 | w += windowsRightBorder; // windows has a strange wide border on the right side |
1019 | 1019 | ||
1020 | return w; | 1020 | return w; |
1021 | #endif | 1021 | #endif |
1022 | } | 1022 | } |
1023 | 1023 | ||
1024 | /*! \reimp | 1024 | /*! \reimp |
1025 | */ | 1025 | */ |
1026 | int QPEStyle::popupMenuItemHeight( bool /*checkable*/, QMenuItem* mi, const QFontMetrics& fm ) | 1026 | int QPEStyle::popupMenuItemHeight( bool /*checkable*/, QMenuItem* mi, const QFontMetrics& fm ) |
1027 | { | 1027 | { |
1028 | #ifndef QT_NO_MENUDATA | 1028 | #ifndef QT_NO_MENUDATA |
1029 | int h = 0; | 1029 | int h = 0; |
1030 | if ( mi->isSeparator() ) // separator height | 1030 | if ( mi->isSeparator() ) // separator height |
1031 | h = motifSepHeight; | 1031 | h = motifSepHeight; |
1032 | else if ( mi->pixmap() ) // pixmap height | 1032 | else if ( mi->pixmap() ) // pixmap height |
1033 | h = mi->pixmap()->height() + 2*motifItemFrame; | 1033 | h = mi->pixmap()->height() + 2*motifItemFrame; |
1034 | else // text height | 1034 | else // text height |
1035 | h = fm.height() + 2*motifItemVMargin + 2*motifItemFrame - 1; | 1035 | h = fm.height() + 2*motifItemVMargin + 2*motifItemFrame - 1; |
1036 | 1036 | ||
1037 | if ( !mi->isSeparator() && mi->iconSet() != 0 ) { | 1037 | if ( !mi->isSeparator() && mi->iconSet() != 0 ) { |
1038 | h = QMAX( h, mi->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height() + 2*motifItemFrame ); | 1038 | h = QMAX( h, mi->iconSet()->pixmap().height() + 2*motifItemFrame ); |
1039 | } | 1039 | } |
1040 | if ( mi->custom() ) | 1040 | if ( mi->custom() ) |
1041 | h = QMAX( h, mi->custom()->sizeHint().height() + 2*motifItemVMargin + 2*motifItemFrame ) - 1; | 1041 | h = QMAX( h, mi->custom()->sizeHint().height() + 2*motifItemVMargin + 2*motifItemFrame ) - 1; |
1042 | return h; | 1042 | return h; |
1043 | #endif | 1043 | #endif |
1044 | } | 1044 | } |
1045 | 1045 | ||
1046 | void QPEStyle::drawPopupMenuItem( QPainter* p, bool checkable, int maxpmw, int tab, QMenuItem* mi, | 1046 | void QPEStyle::drawPopupMenuItem( QPainter* p, bool checkable, int maxpmw, int tab, QMenuItem* mi, |
1047 | const QPalette& pal, | 1047 | const QPalette& pal, |
1048 | bool act, bool enabled, int x, int y, int w, int h) | 1048 | bool act, bool enabled, int x, int y, int w, int h) |
1049 | { | 1049 | { |
1050 | #ifndef QT_NO_MENUDATA | 1050 | #ifndef QT_NO_MENUDATA |
1051 | const QColorGroup & g = pal.active(); | 1051 | const QColorGroup & g = pal.active(); |
1052 | bool dis = !enabled; | 1052 | bool dis = !enabled; |
1053 | QColorGroup itemg = dis ? pal.disabled() : pal.active(); | 1053 | QColorGroup itemg = dis ? pal.disabled() : pal.active(); |
1054 | 1054 | ||
1055 | if ( checkable ) | 1055 | if ( checkable ) |
1056 | maxpmw = QMAX( maxpmw, 8 ); // space for the checkmarks | 1056 | maxpmw = QMAX( maxpmw, 8 ); // space for the checkmarks |
1057 | 1057 | ||
1058 | int checkcol = maxpmw; | 1058 | int checkcol = maxpmw; |
1059 | 1059 | ||
1060 | if ( mi && mi->isSeparator() ) { // draw separator | 1060 | if ( mi && mi->isSeparator() ) { // draw separator |
1061 | p->setPen( g.dark() ); | 1061 | p->setPen( g.dark() ); |
1062 | p->drawLine( x, y, x+w, y ); | 1062 | p->drawLine( x, y, x+w, y ); |
1063 | p->setPen( g.light() ); | 1063 | p->setPen( g.light() ); |
1064 | p->drawLine( x, y+1, x+w, y+1 ); | 1064 | p->drawLine( x, y+1, x+w, y+1 ); |
1065 | return; | 1065 | return; |
1066 | } | 1066 | } |
1067 | 1067 | ||
1068 | QBrush fill = act? g.brush( QColorGroup::Highlight ) : | 1068 | QBrush fill = act? g.brush( QColorGroup::Highlight ) : |
1069 | g.brush( QColorGroup::Button ); | 1069 | g.brush( QColorGroup::Button ); |
1070 | p->fillRect( x, y, w, h, fill); | 1070 | p->fillRect( x, y, w, h, fill); |
1071 | 1071 | ||
1072 | if ( !mi ) | 1072 | if ( !mi ) |
1073 | return; | 1073 | return; |
1074 | 1074 | ||
1075 | if ( mi->isChecked() ) { | 1075 | if ( mi->isChecked() ) { |
1076 | if ( act && !dis ) { | 1076 | if ( act && !dis ) { |
1077 | qDrawShadePanel( p, x, y, checkcol, h, | 1077 | qDrawShadePanel( p, x, y, checkcol, h, |
1078 | g, TRUE, 1, &g.brush( QColorGroup::Button ) ); | 1078 | g, TRUE, 1, &g.brush( QColorGroup::Button ) ); |
1079 | } else { | 1079 | } else { |
1080 | qDrawShadePanel( p, x, y, checkcol, h, | 1080 | qDrawShadePanel( p, x, y, checkcol, h, |
1081 | g, TRUE, 1, &g.brush( QColorGroup::Midlight ) ); | 1081 | g, TRUE, 1, &g.brush( QColorGroup::Midlight ) ); |
1082 | } | 1082 | } |
1083 | } else if ( !act ) { | 1083 | } else if ( !act ) { |
1084 | p->fillRect(x, y, checkcol , h, | 1084 | p->fillRect(x, y, checkcol , h, |
1085 | g.brush( QColorGroup::Button )); | 1085 | g.brush( QColorGroup::Button )); |
1086 | } | 1086 | } |
1087 | 1087 | ||
1088 | if ( mi->iconSet() ) { // draw iconset | 1088 | if ( mi->iconSet() ) { // draw iconset |
1089 | QIconSet::Mode mode = dis ? QIconSet::Disabled : QIconSet::Normal; | 1089 | QIconSet::Mode mode = dis ? QIconSet::Disabled : QIconSet::Normal; |
1090 | if (act && !dis ) | 1090 | if (act && !dis ) |
1091 | mode = QIconSet::Active; | 1091 | mode = QIconSet::Active; |
1092 | QPixmap pixmap = mi->iconSet()->pixmap( QIconSet::Small, mode ); | 1092 | QPixmap pixmap; |
1093 | if ( mode == QIconSet::Disabled ) | ||
1094 | pixmap = mi->iconSet()->pixmap( QIconSet::Automatic, mode ); | ||
1095 | else | ||
1096 | pixmap = mi->iconSet()->pixmap(); | ||
1093 | int pixw = pixmap.width(); | 1097 | int pixw = pixmap.width(); |
1094 | int pixh = pixmap.height(); | 1098 | int pixh = pixmap.height(); |
1095 | if ( act && !dis ) { | 1099 | if ( act && !dis ) { |
1096 | if ( !mi->isChecked() ) | 1100 | if ( !mi->isChecked() ) |
1097 | qDrawShadePanel( p, x, y, checkcol, h, g, FALSE, 1, &g.brush( QColorGroup::Button ) ); | 1101 | qDrawShadePanel( p, x, y, checkcol, h, g, FALSE, 1, &g.brush( QColorGroup::Button ) ); |
1098 | } | 1102 | } |
1099 | QRect cr( x, y, checkcol, h ); | 1103 | QRect cr( x, y, checkcol, h ); |
1100 | QRect pmr( 0, 0, pixw, pixh ); | 1104 | QRect pmr( 0, 0, pixw, pixh ); |
1101 | pmr.moveCenter( cr.center() ); | 1105 | pmr.moveCenter( cr.center() ); |
1102 | p->setPen( itemg.text() ); | 1106 | p->setPen( itemg.text() ); |
1103 | p->drawPixmap( pmr.topLeft(), pixmap ); | 1107 | p->drawPixmap( pmr.topLeft(), pixmap ); |
1104 | 1108 | ||
1105 | QBrush fill = act? g.brush( QColorGroup::Highlight ) : | 1109 | QBrush fill = act? g.brush( QColorGroup::Highlight ) : |
1106 | g.brush( QColorGroup::Button ); | 1110 | g.brush( QColorGroup::Button ); |
1107 | p->fillRect( x+checkcol + 1, y, w - checkcol - 1, h, fill); | 1111 | p->fillRect( x+checkcol + 1, y, w - checkcol - 1, h, fill); |
1108 | } else if ( checkable ) {// just "checking"... | 1112 | } else if ( checkable ) {// just "checking"... |
1109 | int mw = checkcol + motifItemFrame; | 1113 | int mw = checkcol + motifItemFrame; |
1110 | int mh = h - 2*motifItemFrame; | 1114 | int mh = h - 2*motifItemFrame; |
1111 | if ( mi->isChecked() ) { | 1115 | if ( mi->isChecked() ) { |
1112 | drawCheckMark( p, x + motifItemFrame + 2, | 1116 | drawCheckMark( p, x + motifItemFrame + 2, |
1113 | y+motifItemFrame, mw, mh, itemg, act, dis ); | 1117 | y+motifItemFrame, mw, mh, itemg, act, dis ); |
1114 | } | 1118 | } |
1115 | } | 1119 | } |
1116 | 1120 | ||
1117 | p->setPen( act ? g.highlightedText() : g.buttonText() ); | 1121 | p->setPen( act ? g.highlightedText() : g.buttonText() ); |
1118 | 1122 | ||
1119 | QColor discol; | 1123 | QColor discol; |
1120 | if ( dis ) { | 1124 | if ( dis ) { |
1121 | discol = itemg.text(); | 1125 | discol = itemg.text(); |
1122 | p->setPen( discol ); | 1126 | p->setPen( discol ); |
1123 | } | 1127 | } |
1124 | 1128 | ||
1125 | int xm = motifItemFrame + checkcol + motifItemHMargin; | 1129 | int xm = motifItemFrame + checkcol + motifItemHMargin; |
1126 | 1130 | ||
1127 | if ( mi->custom() ) { | 1131 | if ( mi->custom() ) { |
1128 | int m = motifItemVMargin; | 1132 | int m = motifItemVMargin; |
1129 | p->save(); | 1133 | p->save(); |
1130 | if ( dis && !act ) { | 1134 | if ( dis && !act ) { |
1131 | p->setPen( g.light() ); | 1135 | p->setPen( g.light() ); |
1132 | mi->custom()->paint( p, itemg, act, enabled, | 1136 | mi->custom()->paint( p, itemg, act, enabled, |
1133 | x+xm+1, y+m+1, w-xm-tab+1, h-2*m ); | 1137 | x+xm+1, y+m+1, w-xm-tab+1, h-2*m ); |
1134 | p->setPen( discol ); | 1138 | p->setPen( discol ); |
1135 | } | 1139 | } |
1136 | mi->custom()->paint( p, itemg, act, enabled, | 1140 | mi->custom()->paint( p, itemg, act, enabled, |
1137 | x+xm, y+m, w-xm-tab+1, h-2*m ); | 1141 | x+xm, y+m, w-xm-tab+1, h-2*m ); |
1138 | p->restore(); | 1142 | p->restore(); |
1139 | } | 1143 | } |
1140 | QString s = mi->text(); | 1144 | QString s = mi->text(); |
1141 | if ( !s.isNull() ) { // draw text | 1145 | if ( !s.isNull() ) { // draw text |
1142 | int t = s.find( '\t' ); | 1146 | int t = s.find( '\t' ); |
1143 | int m = motifItemVMargin; | 1147 | int m = motifItemVMargin; |
1144 | const int text_flags = AlignVCenter|ShowPrefix | DontClip | SingleLine; | 1148 | const int text_flags = AlignVCenter|ShowPrefix | DontClip | SingleLine; |
1145 | if ( t >= 0 ) { // draw tab text | 1149 | if ( t >= 0 ) { // draw tab text |
1146 | if ( dis && !act ) { | 1150 | if ( dis && !act ) { |
1147 | p->setPen( g.light() ); | 1151 | p->setPen( g.light() ); |
1148 | p->drawText( x+w-tab-windowsRightBorder-motifItemHMargin-motifItemFrame+1, | 1152 | p->drawText( x+w-tab-windowsRightBorder-motifItemHMargin-motifItemFrame+1, |
1149 | y+m+1, tab, h-2*m, text_flags, s.mid( t+1 )); | 1153 | y+m+1, tab, h-2*m, text_flags, s.mid( t+1 )); |
1150 | p->setPen( discol ); | 1154 | p->setPen( discol ); |
1151 | } | 1155 | } |
1152 | p->drawText( x+w-tab-windowsRightBorder-motifItemHMargin-motifItemFrame, | 1156 | p->drawText( x+w-tab-windowsRightBorder-motifItemHMargin-motifItemFrame, |
1153 | y+m, tab, h-2*m, text_flags, s.mid( t+1 ) ); | 1157 | y+m, tab, h-2*m, text_flags, s.mid( t+1 ) ); |
1154 | } | 1158 | } |
1155 | if ( dis && !act ) { | 1159 | if ( dis && !act ) { |
1156 | p->setPen( g.light() ); | 1160 | p->setPen( g.light() ); |
1157 | p->drawText( x+xm+1, y+m+1, w-xm+1, h-2*m, text_flags, s, t ); | 1161 | p->drawText( x+xm+1, y+m+1, w-xm+1, h-2*m, text_flags, s, t ); |
1158 | p->setPen( discol ); | 1162 | p->setPen( discol ); |
1159 | } | 1163 | } |
1160 | p->drawText( x+xm, y+m, w-xm-tab+1, h-2*m, text_flags, s, t ); | 1164 | p->drawText( x+xm, y+m, w-xm-tab+1, h-2*m, text_flags, s, t ); |
1161 | } else if ( mi->pixmap() ) { // draw pixmap | 1165 | } else if ( mi->pixmap() ) { // draw pixmap |
1162 | QPixmap *pixmap = mi->pixmap(); | 1166 | QPixmap *pixmap = mi->pixmap(); |
1163 | if ( pixmap->depth() == 1 ) | 1167 | if ( pixmap->depth() == 1 ) |
1164 | p->setBackgroundMode( OpaqueMode ); | 1168 | p->setBackgroundMode( OpaqueMode ); |
1165 | p->drawPixmap( x+xm, y+motifItemFrame, *pixmap ); | 1169 | p->drawPixmap( x+xm, y+motifItemFrame, *pixmap ); |
1166 | if ( pixmap->depth() == 1 ) | 1170 | if ( pixmap->depth() == 1 ) |
1167 | p->setBackgroundMode( TransparentMode ); | 1171 | p->setBackgroundMode( TransparentMode ); |
1168 | } | 1172 | } |
1169 | if ( mi->popup() ) { // draw sub menu arrow | 1173 | if ( mi->popup() ) { // draw sub menu arrow |
1170 | int dim = (h-2*motifItemFrame) / 2; | 1174 | int dim = (h-2*motifItemFrame) / 2; |
1171 | if ( act ) { | 1175 | if ( act ) { |
1172 | if ( !dis ) | 1176 | if ( !dis ) |
1173 | discol = white; | 1177 | discol = white; |
1174 | QColorGroup g2( discol, g.highlight(), | 1178 | QColorGroup g2( discol, g.highlight(), |
1175 | white, white, | 1179 | white, white, |
1176 | dis ? discol : white, | 1180 | dis ? discol : white, |
1177 | discol, white ); | 1181 | discol, white ); |
1178 | drawArrow( p, RightArrow, FALSE, | 1182 | drawArrow( p, RightArrow, FALSE, |
1179 | x+w - motifArrowHMargin - motifItemFrame - dim, y+h/2-dim/2, | 1183 | x+w - motifArrowHMargin - motifItemFrame - dim, y+h/2-dim/2, |
1180 | dim, dim, g2, TRUE ); | 1184 | dim, dim, g2, TRUE ); |
1181 | } else { | 1185 | } else { |
1182 | drawArrow( p, RightArrow, | 1186 | drawArrow( p, RightArrow, |
1183 | FALSE, | 1187 | FALSE, |
1184 | x+w - motifArrowHMargin - motifItemFrame - dim, y+h/2-dim/2, | 1188 | x+w - motifArrowHMargin - motifItemFrame - dim, y+h/2-dim/2, |
1185 | dim, dim, g, mi->isEnabled() ); | 1189 | dim, dim, g, mi->isEnabled() ); |
1186 | } | 1190 | } |
1187 | } | 1191 | } |
1188 | #endif | 1192 | #endif |
1189 | } | 1193 | } |
1190 | 1194 | ||
1191 | #endif | 1195 | #endif |