23 #include <QResizeEvent>    24 #include <QStyleOptionFrameV3>    26 #include <QHBoxLayout>    29 #include <QFontMetrics>    30 #include <QToolButton>    45   , mCurrentColor( Qt::red )
    46   , mComponent( component )
    48   setAcceptDrops( 
true );
    60   QPixmap pixmap( iconSize, iconSize );
    61   pixmap.fill( Qt::transparent );
    63   painter.begin( &pixmap );
    65   painter.fillRect( QRect( 0, 0, iconSize, iconSize ), QBrush( QColor( 200, 200, 200 ) ) );
    67   QColor pixmapColor = 
color;
    68   pixmapColor.setAlpha( 255 );
    69   painter.setBrush( QBrush( pixmapColor ) );
    70   painter.setPen( QPen( Qt::white ) );
    71   painter.drawRect( QRect( 1, 1, iconSize - 2, iconSize - 2 ) );
   145   color.getHsv( &h, &s, &v, &a );
   148   int clippedValue = std::min( std::max( 0, newValue ), 
componentRange( component ) );
   153       color.setRed( clippedValue );
   156       color.setGreen( clippedValue );
   159       color.setBlue( clippedValue );
   162       color.setHsv( clippedValue, s, v, a );
   165       color.setHsv( h, clippedValue, v, a );
   168       color.setHsv( h, s, clippedValue, a );
   171       color.setAlpha( clippedValue );
   180   static QPixmap sTranspBkgrd;
   182   if ( sTranspBkgrd.isNull() )
   194   if ( mimeColor.isValid() )
   197     e->acceptProposedAction();
   204   bool hasAlpha = 
false;
   207   if ( mimeColor.isValid() )
   210     e->acceptProposedAction();
   269   valueClipped = std::max( valueClipped, 0 );
   281       if ( r == valueClipped )
   288       if ( g == valueClipped )
   295       if ( b == valueClipped )
   302       if ( h == valueClipped )
   309       if ( s == valueClipped )
   316       if ( v == valueClipped )
   323       if ( a == valueClipped )
   352   if ( color.hue() >= 0 )
   374   QConicalGradient wheelGradient = QConicalGradient( 0, 0, 0 );
   376   QColor gradColor = QColor::fromHsvF( 1.0, 1.0, 1.0 );
   377   for ( 
int pos = 0; pos <= wheelStops; ++pos )
   379     double relativePos = 
static_cast<double>( pos ) / wheelStops;
   380     gradColor.setHsvF( relativePos, 1, 1 );
   381     wheelGradient.setColorAt( relativePos, gradColor );
   383   mWheelBrush = QBrush( wheelGradient );
   389   delete mTriangleImage;
   395   int size = 
Qgis::UI_SCALE_FACTOR * fontMetrics().width( QStringLiteral( 
"XXXXXXXXXXXXXXXXXXXXXX" ) );
   396   return QSize( size, size );
   402   QPainter painter( 
this );
   404   if ( !mWidgetImage || !mWheelImage || !mTriangleImage )
   406     createImages( size() );
   410   mWidgetImage->fill( Qt::transparent );
   411   QPainter imagePainter( mWidgetImage );
   412   imagePainter.setRenderHint( QPainter::Antialiasing );
   421   QPointF center = QPointF( width() / 2.0, height() / 2.0 );
   422   imagePainter.drawImage( QPointF( center.x() - ( mWheelImage->width() / 2.0 ), center.y() - ( mWheelImage->height() / 2.0 ) ), *mWheelImage );
   426   double length = mWheelImage->width() / 2.0;
   427   QLineF hueMarkerLine = QLineF( center.x(), center.y(), center.x() + length, center.y() );
   428   hueMarkerLine.setAngle( h );
   431   imagePainter.setCompositionMode( QPainter::CompositionMode_SourceIn );
   435   pen.setColor( h > 20 && h < 200 ? Qt::black : Qt::white );
   436   imagePainter.setPen( pen );
   437   imagePainter.drawLine( hueMarkerLine );
   438   imagePainter.restore();
   441   if ( mTriangleDirty )
   445   imagePainter.drawImage( QPointF( center.x() - ( mWheelImage->width() / 2.0 ), center.y() - ( mWheelImage->height() / 2.0 ) ), *mTriangleImage );
   448   double triangleRadius = length - mWheelThickness - 1;
   452   double hueRadians = ( h * M_PI / 180.0 );
   453   double hx = std::cos( hueRadians ) * triangleRadius;
   454   double hy = -std::sin( hueRadians ) * triangleRadius;
   455   double sx = -std::cos( -hueRadians + ( M_PI / 3.0 ) ) * triangleRadius;
   456   double sy = -std::sin( -hueRadians + ( M_PI / 3.0 ) ) * triangleRadius;
   457   double vx = -std::cos( hueRadians + ( M_PI / 3.0 ) ) * triangleRadius;
   458   double vy = std::sin( hueRadians + ( M_PI / 3.0 ) ) * triangleRadius;
   459   double mx = ( sx + vx ) / 2.0;
   460   double  my = ( sy + vy ) / 2.0;
   462   double a = ( 1 - 2.0 * std::fabs( lightness - 0.5 ) ) * 
mCurrentColor.hslSaturationF();
   463   double x = sx + ( vx - sx ) * lightness + ( hx - mx ) * a;
   464   double y = sy + ( vy - sy ) * lightness + ( hy - my ) * a;
   467   pen.setColor( lightness > 0.7 ? Qt::black : Qt::white );
   468   imagePainter.setPen( pen );
   469   imagePainter.setBrush( Qt::NoBrush );
   470   imagePainter.drawEllipse( QPointF( x + center.x(), y + center.y() ), 4.0, 4.0 );
   474   painter.drawImage( QPoint( 0, 0 ), *mWidgetImage );
   480   if ( color.hue() >= 0 && color.hue() != 
hue() )
   483     mTriangleDirty = 
true;
   489 void QgsColorWheel::createImages( 
const QSizeF size )
   491   double wheelSize = std::min( size.width(), size.height() ) - mMargin * 2.0;
   492   mWheelThickness = wheelSize / 15.0;
   496   mWheelImage = 
new QImage( wheelSize, wheelSize, QImage::Format_ARGB32 );
   497   delete mTriangleImage;
   498   mTriangleImage = 
new QImage( wheelSize, wheelSize, QImage::Format_ARGB32 );
   500   mWidgetImage = 
new QImage( size.width(), size.height(), QImage::Format_ARGB32 );
   504   mTriangleDirty = 
true;
   510   createImages( event->size() );
   511   QgsColorWidget::resizeEvent( event );
   514 void QgsColorWheel::setColorFromPos( 
const QPointF pos )
   516   QPointF center = QPointF( width() / 2.0, height() / 2.0 );
   518   QLineF line = QLineF( center.x(), center.y(), pos.x(), pos.y() );
   520   QColor newColor = QColor();
   527   if ( mClickedPart == QgsColorWheel::Triangle )
   532     double x = pos.x() - center.x();
   533     double y = pos.y() - center.y();
   535     double eventAngleRadians = line.angle() * M_PI / 180.0;
   536     double hueRadians = h * M_PI / 180.0;
   537     double rad0 = std::fmod( eventAngleRadians + 2.0 * M_PI - hueRadians, 2.0 * M_PI );
   538     double rad1 = std::fmod( rad0, ( ( 2.0 / 3.0 ) * M_PI ) ) - ( M_PI / 3.0 );
   539     double length = mWheelImage->width() / 2.0;
   540     double triangleLength = length - mWheelThickness - 1;
   542     double a = 0.5 * triangleLength;
   543     double b = std::tan( rad1 ) * a;
   544     double r = std::sqrt( x * x + y * y );
   545     double maxR = std::sqrt( a * a + b * b );
   549       double dx = std::tan( rad1 ) * r;
   550       double rad2 = std::atan( dx / maxR );
   551       rad2 = std::min( rad2, M_PI / 3.0 );
   552       rad2 = std::max( rad2, -M_PI / 3.0 );
   553       eventAngleRadians += rad2 - rad1;
   554       rad0 = std::fmod( eventAngleRadians + 2.0 * M_PI - hueRadians, 2.0 * M_PI );
   555       rad1 = std::fmod( rad0, ( ( 2.0 / 3.0 ) * M_PI ) ) - ( M_PI / 3.0 );
   556       b = std::tan( rad1 ) * a;
   557       r = std::sqrt( a * a + b * b );
   560     double triangleSideLength = std::sqrt( 3.0 ) * triangleLength;
   561     double newL = ( ( -std::sin( rad0 ) * r ) / triangleSideLength ) + 0.5;
   562     double widthShare = 1.0 - ( std::fabs( newL - 0.5 ) * 2.0 );
   563     double newS = ( ( ( std::cos( rad0 ) * r ) + ( triangleLength / 2.0 ) ) / ( 1.5 * triangleLength ) ) / widthShare;
   564     s = std::min( static_cast< int >( std::round( std::max( 0.0, newS ) * 255.0 ) ), 255 );
   565     l = std::min( static_cast< int >( std::round( std::max( 0.0, newL ) * 255.0 ) ), 255 );
   566     newColor = QColor::fromHsl( h, s, l );
   568     newColor.setHsv( h, newColor.hsvSaturation(), newColor.value(), alpha );
   570   else if ( mClickedPart == QgsColorWheel::Wheel )
   575     int newHue = line.angle();
   576     newColor = QColor::fromHsv( newHue, s, v, alpha );
   578     mTriangleDirty = 
true;
   599   setColorFromPos( event->pos() );
   608   QLineF line = QLineF( width() / 2.0, height() / 2.0, event->pos().x(), 
event->pos().y() );
   610   double innerLength = mWheelImage->width() / 2.0 - mWheelThickness;
   611   if ( line.length() < innerLength )
   613     mClickedPart = QgsColorWheel::Triangle;
   617     mClickedPart = QgsColorWheel::Wheel;
   619   setColorFromPos( event->pos() );
   625   mClickedPart = QgsColorWheel::None;
   628 void QgsColorWheel::createWheel()
   635   int maxSize = std::min( mWheelImage->width(),  mWheelImage->height() );
   636   double wheelRadius = maxSize / 2.0;
   638   mWheelImage->fill( Qt::transparent );
   639   QPainter p( mWheelImage );
   640   p.setRenderHint( QPainter::Antialiasing );
   641   p.setBrush( mWheelBrush );
   642   p.setPen( Qt::NoPen );
   645   p.translate( wheelRadius, wheelRadius );
   646   p.drawEllipse( QPointF( 0.0, 0.0 ), wheelRadius, wheelRadius );
   649   p.setCompositionMode( QPainter::CompositionMode_DestinationOut );
   650   p.setBrush( QBrush( Qt::black ) );
   651   p.drawEllipse( QPointF( 0.0, 0.0 ), wheelRadius - mWheelThickness, wheelRadius  - mWheelThickness );
   657 void QgsColorWheel::createTriangle()
   659   if ( !mWheelImage || !mTriangleImage )
   664   QPointF center = QPointF( mWheelImage->width() / 2.0, mWheelImage->height() / 2.0 );
   665   mTriangleImage->fill( Qt::transparent );
   667   QPainter imagePainter( mTriangleImage );
   668   imagePainter.setRenderHint( QPainter::Antialiasing );
   671   double wheelRadius = mWheelImage->width() / 2.0;
   672   double triangleRadius = wheelRadius - mWheelThickness - 1;
   675   QColor pureColor = QColor::fromHsv( angle, 255, 255 );
   677   QColor alphaColor = QColor( pureColor );
   678   alphaColor.setAlpha( 0 );
   681   QLineF line1 = QLineF( center.x(), center.y(), center.x() - triangleRadius * std::cos( M_PI / 3.0 ), center.y() - triangleRadius * std::sin( M_PI / 3.0 ) );
   682   QLineF line2 = QLineF( center.x(), center.y(), center.x() + triangleRadius, center.y() );
   683   QLineF line3 = QLineF( center.x(), center.y(), center.x() - triangleRadius * std::cos( M_PI / 3.0 ), center.y() + triangleRadius * std::sin( M_PI / 3.0 ) );
   684   QLineF line4 = QLineF( center.x(), center.y(), center.x() - triangleRadius * std::cos( M_PI / 3.0 ), center.y() );
   685   QLineF line5 = QLineF( center.x(), center.y(), ( line2.p2().x() + line1.p2().x() ) / 2.0, ( line2.p2().y() + line1.p2().y() ) / 2.0 );
   686   line1.setAngle( line1.angle() + 
angle );
   687   line2.setAngle( line2.angle() + 
angle );
   688   line3.setAngle( line3.angle() + 
angle );
   689   line4.setAngle( line4.angle() + 
angle );
   690   line5.setAngle( line5.angle() + 
angle );
   691   QPointF p1 = line1.p2();
   692   QPointF p2 = line2.p2();
   693   QPointF p3 = line3.p2();
   694   QPointF p4 = line4.p2();
   695   QPointF p5 = line5.p2();
   698   QLinearGradient colorGrad = QLinearGradient( p4.x(), p4.y(), p2.x(), p2.y() );
   699   colorGrad.setColorAt( 0, alphaColor );
   700   colorGrad.setColorAt( 1, pureColor );
   701   QLinearGradient whiteGrad = QLinearGradient( p3.x(), p3.y(), p5.x(), p5.y() );
   702   whiteGrad.setColorAt( 0, QColor( 255, 255, 255, 255 ) );
   703   whiteGrad.setColorAt( 1, QColor( 255, 255, 255, 0 ) );
   706   triangle << p2 << p1 << p3 << p2;
   707   imagePainter.setPen( Qt::NoPen );
   709   imagePainter.setBrush( QBrush( Qt::black ) );
   710   imagePainter.drawPolygon( triangle );
   712   imagePainter.setBrush( QBrush( colorGrad ) );
   713   imagePainter.drawPolygon( triangle );
   715   imagePainter.setCompositionMode( QPainter::CompositionMode_Plus );
   716   imagePainter.setBrush( QBrush( whiteGrad ) );
   717   imagePainter.drawPolygon( triangle );
   722   imagePainter.setCompositionMode( QPainter::CompositionMode_Source );
   723   imagePainter.setBrush( Qt::NoBrush );
   724   imagePainter.setPen( QPen( Qt::transparent ) );
   725   imagePainter.drawPolygon( triangle );
   728   mTriangleDirty = 
false;
   740   setFocusPolicy( Qt::StrongFocus );
   741   setSizePolicy( QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding );
   743   mBoxImage = 
new QImage( width() - mMargin * 2, height() - mMargin * 2, QImage::Format_RGB32 );
   753   int size = 
Qgis::UI_SCALE_FACTOR * fontMetrics().width( QStringLiteral( 
"XXXXXXXXXXXXXXXXXXXXXX" ) );
   754   return QSize( size, size );
   760   QPainter painter( 
this );
   762   QStyleOptionFrame option;
   763   option.initFrom( 
this );
   764   option.state = hasFocus() ? QStyle::State_Active :  QStyle::State_None;
   765   style()->drawPrimitive( QStyle::PE_Frame, &option, &painter );
   773   painter.drawImage( QPoint( mMargin, mMargin ), *mBoxImage );
   776   double xPos = mMargin + ( width() - 2 * mMargin - 1 ) * static_cast<double>( xComponentValue() ) / static_cast<double>( valueRangeX() );
   777   double yPos = mMargin + ( height() - 2 * mMargin - 1 ) - ( height() - 2 * mMargin - 1 ) * static_cast<double>( yComponentValue() ) / static_cast<double>( valueRangeY() );
   779   painter.setBrush( Qt::white );
   780   painter.setPen( Qt::NoPen );
   782   painter.drawRect( xPos - 1, mMargin, 3, height() - 2 * mMargin - 1 );
   783   painter.drawRect( mMargin, yPos - 1, width() - 2 * mMargin - 1, 3 );
   784   painter.setPen( Qt::black );
   785   painter.drawLine( xPos, mMargin, xPos, height() - mMargin - 1 );
   786   painter.drawLine( mMargin, yPos, width() - mMargin - 1, yPos );
   835   mBoxImage = 
new QImage( event->size().width() - mMargin * 2, 
event->size().height() - mMargin * 2, QImage::Format_RGB32 );
   836   QgsColorWidget::resizeEvent( event );
   841   setColorFromPoint( event->pos() );
   847   setColorFromPoint( event->pos() );
   850 void QgsColorBox::createBox()
   852   int maxValueX = mBoxImage->width();
   853   int maxValueY = mBoxImage->height();
   857   int colorComponentValue;
   859   for ( 
int y = 0; y < maxValueY; ++y )
   861     QRgb *scanLine = ( QRgb * )mBoxImage->scanLine( y );
   863     colorComponentValue = int( valueRangeY() - valueRangeY() * ( 
double( y ) / maxValueY ) );
   864     alterColor( currentColor, yComponent(), colorComponentValue );
   865     for ( 
int x = 0; x < maxValueX; ++x )
   867       colorComponentValue = int( valueRangeX() * ( 
double( x ) / maxValueX ) );
   868       alterColor( currentColor, xComponent(), colorComponentValue );
   869       scanLine[x] = currentColor.rgb();
   875 int QgsColorBox::valueRangeX()
 const   880 int QgsColorBox::valueRangeY()
 const   905 int QgsColorBox::yComponentValue()
 const   930 int QgsColorBox::xComponentValue()
 const   935 void QgsColorBox::setColorFromPoint( QPoint point )
   937   int valX = valueRangeX() * ( point.x() - mMargin ) / ( width() - 2 * mMargin - 1 );
   938   valX = std::min( std::max( valX, 0 ), valueRangeX() );
   940   int valY = valueRangeY() - valueRangeY() * ( point.y() - mMargin ) / ( height() - 2 * mMargin - 1 );
   941   valY = std::min( std::max( valY, 0 ), valueRangeY() );
   952   if ( color.hue() >= 0 )
   972   setFocusPolicy( Qt::StrongFocus );
   996   QPainter painter( 
this );
  1001     QStyleOptionFrame option;
  1002     option.initFrom( 
this );
  1003     option.state = hasFocus() ? QStyle::State_KeyboardFocusChange : QStyle::State_None;
  1004     style()->drawPrimitive( QStyle::PE_Frame, &option, &painter );
  1010     QStyleOptionFocusRect option;
  1011     option.initFrom( 
this );
  1012     option.state = QStyle::State_KeyboardFocusChange;
  1013     style()->drawPrimitive( QStyle::PE_FrameFocusRect, &option, &painter );
  1020     color.setAlpha( 255 );
  1027     painter.setPen( pen );
  1028     painter.setBrush( Qt::NoBrush );
  1031     for ( 
int c = 0; 
c <= maxValue; ++
c )
  1033       int colorVal = 
static_cast<int>( 
componentRange() * 
static_cast<double>( 
c ) / maxValue );
  1040       if ( color.hue() < 0 )
  1042         color.setHsv( 
hue(), color.saturation(), color.value() );
  1044       pen.setColor( color );
  1045       painter.setPen( pen );
  1049         painter.drawLine( QLineF( 
c + mMargin, mMargin, 
c + mMargin, height() - mMargin - 1 ) );
  1054         painter.drawLine( QLineF( mMargin, 
c + mMargin, width() - mMargin - 1, 
c + mMargin ) );
  1063     painter.setBrush( checkBrush );
  1064     painter.setPen( Qt::NoPen );
  1065     painter.drawRect( QRectF( mMargin, mMargin, width() - 2 * mMargin - 1, height() - 2 * mMargin - 1 ) );
  1066     QLinearGradient colorGrad;
  1070       colorGrad = QLinearGradient( mMargin, 0, width() - mMargin - 1, 0 );
  1075       colorGrad = QLinearGradient( 0, mMargin, 0, height() - mMargin - 1 );
  1078     transparent.setAlpha( 0 );
  1079     colorGrad.setColorAt( 0, transparent );
  1081     opaque.setAlpha( 255 );
  1082     colorGrad.setColorAt( 1, opaque );
  1083     QBrush colorBrush = QBrush( colorGrad );
  1084     painter.setBrush( colorBrush );
  1085     painter.drawRect( QRectF( mMargin, mMargin, width() - 2 * mMargin - 1, height() - 2 * mMargin - 1 ) );
  1091     painter.setRenderHint( QPainter::Antialiasing );
  1092     painter.setBrush( QBrush( Qt::black ) );
  1093     painter.setPen( Qt::NoPen );
  1095     painter.drawPolygon( mTopTriangle );
  1096     painter.translate( 0, height() - mMargin - 2 );
  1097     painter.setBrush( QBrush( Qt::white ) );
  1098     painter.drawPolygon( mBottomTriangle );
  1104     double ypos = mMargin + ( height() - 2 * mMargin - 1 ) - ( height() - 2 * mMargin - 1 ) * static_cast<double>( 
componentValue() ) / 
componentRange();
  1105     painter.setBrush( Qt::white );
  1106     painter.setPen( Qt::NoPen );
  1107     painter.drawRect( QRectF( mMargin, ypos - 1, width() - 2 * mMargin - 1, 3 ) );
  1108     painter.setPen( Qt::black );
  1109     painter.drawLine( QLineF( mMargin, ypos, width() - mMargin - 1, ypos ) );
  1119     setSizePolicy( QSizePolicy::MinimumExpanding, QSizePolicy::Fixed );
  1124     setSizePolicy( QSizePolicy::Fixed, QSizePolicy::MinimumExpanding );
  1131   if ( margin == mMargin )
  1141   if ( showFrame == mShowFrame )
  1152   mTopTriangle << QPoint( -markerSize, 0 ) <<  QPoint( markerSize, 0 ) << QPoint( 0, markerSize );
  1153   mBottomTriangle << QPoint( -markerSize, 0 ) << QPoint( markerSize, 0 ) << QPoint( 0, -markerSize );
  1159   setColorFromPoint( event->pos() );
  1167   if ( event->delta() > 0 )
  1188   setColorFromPoint( event->pos() );
  1227     QgsColorWidget::keyPressEvent( event );
  1239 void QgsColorRampWidget::setColorFromPoint( QPointF point )
  1245     val = 
componentRange() * ( point.x() - mMargin ) / ( width() - 2 * mMargin );
  1270   QHBoxLayout *hLayout = 
new QHBoxLayout();
  1271   hLayout->setMargin( 0 );
  1272   hLayout->setSpacing( 5 );
  1276   hLayout->addWidget( mRampWidget, 1 );
  1278   mSpinBox = 
new QSpinBox();
  1280   int largestCharWidth = mSpinBox->fontMetrics().width( QStringLiteral( 
"888%" ) );
  1281   mSpinBox->setMinimumWidth( largestCharWidth + 35 );
  1282   mSpinBox->setMinimum( 0 );
  1283   mSpinBox->setMaximum( convertRealToDisplay( 
componentRange() ) );
  1288     mSpinBox->setSuffix( QChar( 176 ) );
  1292     mSpinBox->setSuffix( tr( 
"%" ) );
  1294   hLayout->addWidget( mSpinBox );
  1295   setLayout( hLayout );
  1299   connect( mSpinBox, static_cast < 
void ( QSpinBox::* )( 
int ) > ( &QSpinBox::valueChanged ), 
this, &QgsColorSliderWidget::spinChanged );
  1306   mSpinBox->setMaximum( convertRealToDisplay( 
componentRange() ) );
  1310     mSpinBox->setSuffix( QChar( 176 ) );
  1315     mSpinBox->setSuffix( tr( 
"%" ) );
  1320     mSpinBox->setSuffix( QString() );
  1327   mRampWidget->blockSignals( 
true );
  1329   mRampWidget->blockSignals( 
false );
  1330   mSpinBox->blockSignals( 
true );
  1331   mSpinBox->setValue( convertRealToDisplay( value ) );
  1332   mSpinBox->blockSignals( 
false );
  1339   mSpinBox->blockSignals( 
true );
  1341   mSpinBox->blockSignals( 
false );
  1344 void QgsColorSliderWidget::rampColorChanged( 
const QColor &
color )
  1349 void QgsColorSliderWidget::spinChanged( 
int value )
  1351   int convertedValue = convertDisplayToReal( value );
  1357 void QgsColorSliderWidget::rampChanged( 
int value )
  1359   mSpinBox->blockSignals( 
true );
  1360   mSpinBox->setValue( convertRealToDisplay( value ) );
  1361   mSpinBox->blockSignals( 
false );
  1365 int QgsColorSliderWidget::convertRealToDisplay( 
const int realValue )
 const  1371     return std::round( 100.0 * realValue / 255.0 );
  1378 int QgsColorSliderWidget::convertDisplayToReal( 
const int displayValue )
 const  1383     return std::round( 255.0 * displayValue / 100.0 );
  1387   return displayValue;
  1397   QHBoxLayout *hLayout = 
new QHBoxLayout();
  1398   hLayout->setMargin( 0 );
  1399   hLayout->setSpacing( 0 );
  1401   mLineEdit = 
new QLineEdit( 
nullptr );
  1402   hLayout->addWidget( mLineEdit );
  1404   mMenuButton = 
new QToolButton( mLineEdit );
  1406   mMenuButton->setCursor( Qt::ArrowCursor );
  1407   mMenuButton->setFocusPolicy( Qt::NoFocus );
  1408   mMenuButton->setStyleSheet( QStringLiteral( 
"QToolButton { border: none; padding: 0px; }" ) );
  1410   setLayout( hLayout );
  1412   int frameWidth = mLineEdit->style()->pixelMetric( QStyle::PM_DefaultFrameWidth );
  1413   mLineEdit->setStyleSheet( QStringLiteral( 
"QLineEdit { padding-right: %1px; } " )
  1414                             .arg( mMenuButton->sizeHint().width() + frameWidth + 1 ) );
  1416   connect( mLineEdit, &QLineEdit::editingFinished, 
this, &QgsColorTextWidget::textChanged );
  1417   connect( mMenuButton, &QAbstractButton::clicked, 
this, &QgsColorTextWidget::showMenu );
  1421   mFormat = settings.
enumValue( QStringLiteral( 
"ColorWidgets/textWidgetFormat" ), 
HexRgb );
  1435   QSize sz = mMenuButton->sizeHint();
  1436   int frameWidth = style()->pixelMetric( QStyle::PM_DefaultFrameWidth );
  1437   mMenuButton->move( mLineEdit->rect().right() - frameWidth - sz.width(),
  1438                      ( mLineEdit->rect().bottom() + 1 - sz.height() ) / 2 );
  1441 void QgsColorTextWidget::updateText()
  1460 void QgsColorTextWidget::textChanged()
  1462   QString testString = mLineEdit->text();
  1465   if ( !color.isValid() )
  1476     if ( !containsAlpha )
  1487 void QgsColorTextWidget::showMenu()
  1489   QMenu colorContextMenu;
  1491   QAction *hexRgbAction = 
new QAction( tr( 
"#RRGGBB" ), 
nullptr );
  1492   colorContextMenu.addAction( hexRgbAction );
  1493   QAction *hexRgbaAction = 
new QAction( tr( 
"#RRGGBBAA" ), 
nullptr );
  1494   colorContextMenu.addAction( hexRgbaAction );
  1495   QAction *rgbAction = 
new QAction( tr( 
"rgb( r, g, b )" ), 
nullptr );
  1496   colorContextMenu.addAction( rgbAction );
  1497   QAction *rgbaAction = 
new QAction( tr( 
"rgba( r, g, b, a )" ), 
nullptr );
  1498   colorContextMenu.addAction( rgbaAction );
  1500   QAction *selectedAction = colorContextMenu.exec( QCursor::pos() );
  1501   if ( selectedAction == hexRgbAction )
  1505   else if ( selectedAction == hexRgbaAction )
  1509   else if ( selectedAction == rgbAction )
  1513   else if ( selectedAction == rgbaAction )
  1520   settings.
setEnumValue( QStringLiteral( 
"ColorWidgets/textWidgetFormat" ), mFormat );
  1532   , mColor2( QColor() )
  1537 void QgsColorPreviewWidget::drawColor( 
const QColor &
color, QRect rect, QPainter &painter )
  1539   painter.setPen( Qt::NoPen );
  1541   if ( 
color.alpha() < 255 )
  1544     painter.setBrush( checkBrush );
  1545     painter.drawRect( rect );
  1550     QBrush colorBrush = QBrush( 
color );
  1551     painter.setBrush( colorBrush );
  1552     painter.drawRect( std::floor( rect.width() / 2.0 ) + rect.left(), rect.top(), rect.width() - std::floor( rect.width() / 2.0 ), rect.height() );
  1554     QColor opaqueColor = QColor( 
color );
  1555     opaqueColor.setAlpha( 255 );
  1556     QBrush opaqueBrush = QBrush( opaqueColor );
  1557     painter.setBrush( opaqueBrush );
  1558     painter.drawRect( rect.left(), rect.top(), std::ceil( rect.width() / 2.0 ), rect.height() );
  1563     QBrush brush = QBrush( 
color );
  1564     painter.setBrush( brush );
  1565     painter.drawRect( rect );
  1572   QPainter painter( 
this );
  1574   if ( mColor2.isValid() )
  1577     int verticalSplit = std::round( height() / 2.0 );
  1578     drawColor( 
mCurrentColor, QRect( 0, 0, width(), verticalSplit ), painter );
  1579     drawColor( mColor2, QRect( 0, verticalSplit, width(), height() - verticalSplit ), painter );
  1583     drawColor( 
mCurrentColor, QRect( 0, 0, width(), height() ), painter );
  1596   if ( color == mColor2 )
  1606   if ( e->button() == Qt::LeftButton )
  1608     mDragStartPosition = e->pos();
  1615   if ( ( e->pos() - mDragStartPosition ).manhattanLength() >= QApplication::startDragDistance() )
  1624   if ( mColor2.isValid() )
  1627     int verticalSplit = std::round( height() / 2.0 );
  1628     if ( mDragStartPosition.y() >= verticalSplit )
  1630       clickedColor = mColor2;
  1641   if ( !( e->buttons() & Qt::LeftButton ) )
  1648   if ( ( e->pos() - mDragStartPosition ).manhattanLength() < QApplication::startDragDistance() )
  1659   if ( mColor2.isValid() )
  1662     int verticalSplit = std::round( height() / 2.0 );
  1663     if ( mDragStartPosition.y() >= verticalSplit )
  1665       dragColor = mColor2;
  1669   QDrag *drag = 
new QDrag( 
this );
  1672   drag->exec( Qt::CopyAction );
  1681   : QWidgetAction( parent )
  1683   , mColorWidget( colorWidget )
  1684   , mSuppressRecurse( false )
  1685   , mDismissOnColorSelection( true )
  1687   setDefaultWidget( mColorWidget );
  1690   connect( 
this, &QAction::hovered, 
this, &QgsColorWidgetAction::onHover );
  1694 void QgsColorWidgetAction::onHover()
  1697   if ( mSuppressRecurse )
  1704     mSuppressRecurse = 
true;
  1705     mMenu->setActiveAction( 
this );
  1706     mSuppressRecurse = 
false;
  1710 void QgsColorWidgetAction::setColor( 
const QColor &color )
  1714   if ( mMenu && mDismissOnColorSelection )
 
static const double UI_SCALE_FACTOR
UI scaling factor. 
 
This class is a composition of two QSettings instances: 
 
int scaleIconSize(int standardSize)
Scales an icon size to compensate for display pixel density, making the icon size hi-dpi friendly...
 
void paintEvent(QPaintEvent *event) override
 
static QIcon getThemeIcon(const QString &name)
Helper to get a theme icon. 
 
void mouseReleaseEvent(QMouseEvent *event) override
 
QSize sizeHint() const override
 
void mousePressEvent(QMouseEvent *event) override
 
double ANALYSIS_EXPORT angle(QgsPoint *p1, QgsPoint *p2, QgsPoint *p3, QgsPoint *p4)
Calculates the angle between two segments (in 2 dimension, z-values are ignored) 
 
static QPixmap getThemePixmap(const QString &name)
Helper to get a theme icon as a pixmap. 
 
void mousePressEvent(QMouseEvent *event) override
 
As part of the API refactoring and improvements which landed in the Processing API was substantially reworked from the x version This was done in order to allow much of the underlying Processing framework to be ported into c
 
~QgsColorWheel() override
 
static QColor parseColorWithAlpha(const QString &colorStr, bool &containsAlpha, bool strictEval=false)
Attempts to parse a string as a color using a variety of common formats, including hex codes...
 
void setComponent(ColorComponent component) override
Sets the color component which the widget controls. 
 
void resizeEvent(QResizeEvent *event) override
 
QgsColorWheel(QWidget *parent=nullptr)
Constructs a new color wheel widget. 
 
void setColor(const QColor &color, bool emitSignals=false) override
 
#RRGGBBAA in hexadecimal, with alpha 
 
void paintEvent(QPaintEvent *event) override
 
void resizeEvent(QResizeEvent *event) override
 
void setEnumValue(const QString &key, const T &value, const Section section=NoSection)
Set the value of a setting based on an enum. 
 
void setColor(const QColor &color, bool emitSignals=false) override
 
static QMimeData * colorToMimeData(const QColor &color)
Creates mime data from a color. 
 
QgsColorTextWidget(QWidget *parent=nullptr)
Construct a new color line edit widget. 
 
QSize sizeHint() const override
 
T enumValue(const QString &key, const T &defaultValue, const Section section=NoSection)
Returns the setting value for a setting based on an enum. 
 
void mouseMoveEvent(QMouseEvent *event) override
 
QgsColorBox(QWidget *parent=nullptr, ColorComponent component=Value)
Construct a new color box widget. 
 
void mouseMoveEvent(QMouseEvent *event) override
 
void resizeEvent(QResizeEvent *event) override
 
void setColor(const QColor &color, bool emitSignals=false) override
Sets the color for the widget. 
 
Rgba( r, g, b, a ) format, with alpha. 
 
static QColor colorFromMimeData(const QMimeData *data, bool &hasAlpha)
Attempts to parse mime data as a color.