| LEADTOOLS Raster Imaging C DLL Help > Function References > L_EfxGradientFillRect | 
#include "l_bitmap.h"
L_LTEFX_API L_INT L_EfxGradientFillRect(hDC, pRect, uStyle, crStart, crEnd, uSteps)
| HDC hDC; | /* handle to the target device context */ | 
| RECT * pRect; | /* pointer to the display rectangle */ | 
| L_UINT uStyle; | /* gradient style */ | 
| COLORREF crStart; | /* starting color */ | 
| COLORREF crEnd; | /* ending color */ | 
| L_UINT uSteps; | /* number of gradient color steps */ | 
Draws a rectangle into the target device context, and then fills the rectangle with a gradient from the specified starting color to the specified ending color.
| Parameter | Description | 
| hDC | Handle to the target device context. | 
| pRect | Pointer to the display destination rectangle. | 
| uStyle | Gradient style. For valid values, refer to Effect Gradient Styles. | 
| crStart | COLORREF value that specifies the starting color. | 
| crEnd | COLORREF value that specifies the ending color. | 
| uSteps | Number of gradient color steps. Valid values are 2 to 256. | 
Returns
| SUCCESS | The function was successful. | 
| < 1 | An error occurred. Refer to Return Codes. | 
Required DLLs and Libraries
| For a listing of the exact DLLs and Libraries needed, based on the toolkit version, refer to Files To Be Included With Your Application. | 
Platforms
Win32, x64.
See Also
| Functions: | L_EfxDraw3dShape, L_EfxDraw3dText, L_EfxDrawFrame, L_EfxDrawRotated3dText, L_EfxEffectBlt, L_EfxPaintBitmap, L_EfxPaintTransition, L_EfxPatternFillRect. L_EfxTileRect | 
| Topics: | |
| 
 | 
Example
This example shows the minimum requirements for using the L_EfxGradientFillRect function to draw and fill a rectangle with a color gradient.
 L_INT EfxGradientFillRectExample(HWND    hWnd,RECT*   pDest)
{
  L_INT nRet;
  HDC       hdc; /* Device context for the current window */
  HPALETTE  hSavedPalette = NULL; /* Temporary copy of the current system palette */
  HPALETTE  hOurPalette = NULL;  /* The palette that we will use to paint */
  L_INT     nBitsPerPixel;
  /* Get the device context */
  hdc = GetDC (hWnd);
  /* Check the device to see if we need a palette */
  nBitsPerPixel = GetDeviceCaps( hdc, BITSPIXEL ) * GetDeviceCaps ( hdc, PLANES );
  if ( nBitsPerPixel <=8 )
  {
    hOurPalette = (HPALETTE)GetStockObject (DEFAULT_PALETTE);
    hSavedPalette = SelectPalette (hdc, hOurPalette, FALSE);
    /* Realize our palette */
    RealizePalette (hdc); 
  }
  /* Draw the gradient filled rectangle */
  nRet = L_EfxGradientFillRect(hdc,                       /* device context */
                        pDest,                     /* destination rectangle */
                        EFX_GRADIENT_ELLIPSE_TO_C, /* out to center */
                        RGB ( 255,0,0 ),           /* starting color, red */
                        RGB ( 0,0,255 ),           /* ending color, blue */
                        12 );                      /* gradient color steps */
  if(nRet != SUCCESS)
     return nRet;
  /* Restore the old palette */
  if  ( hOurPalette )
    SelectPalette (hdc, hSavedPalette, FALSE);
  /* Release the device context */
  ReleaseDC(hWnd, hdc);
   return SUCCESS;
}