Logo ROOT   6.14/05
Reference Guide

Detailed Description

Gradient fill with transparency and "SAME" option.

Requires OS X and ROOT configured with –enable-cocoa.

//Includes for ACLiC (cling does not need them).
#include "TColorGradient.h"
#include "TVirtualX.h"
#include "TCanvas.h"
#include "TError.h"
#include "TColor.h"
#include "TH1F.h"
//Aux. functions for tutorials/cocoa.
#include "customcolor.h"
void grad2()
{
//1. 'Allocate' four indices for our custom colors.
//We can use hard-coded indices like 1001, 1002, 1003 ... but
//I prefer to find free indices in the ROOT's color table
//to avoid possible conflicts with other tutorials.
Color_t freeIndices[4] = {};
::Error("grad2", "can not allocate new custom colors");
return;
}
//'Aliases' (instead of freeIndices[someIndex])
const Color_t customRed = freeIndices[0], grad1 = freeIndices[1];
const Color_t customGreen = freeIndices[2], grad2 = freeIndices[3];
//2. Check that we are ROOT with Cocoa back-end enabled.
TCanvas * const cnv = new TCanvas("gradient demo 2", "gradient demo 2", 100, 100, 800, 600);
//After canvas was created, gVirtualX should be non-null.
if (gVirtualX && !gVirtualX->InheritsFrom("TGCocoa")) {
::Error("grad2", "This macro works only on OS X with --enable-cocoa");
delete cnv;
return;
}
//3. Custom colors:
// a) Custom semi-transparent red.
new TColor(customRed, 1., 0., 0., "red", 0.5);
// b) Gradient (from our semi-transparent red to ROOT's kOrange).
// Linear gradient is defined by: 1) colors (to interpolate between them),
// 2) coordinates for these colors along the gradient axis [0., 1.] (must be sorted!).
// 3) Start and end points for a gradient, you specify them in some NDC rect ([0,0 - 1,1]),
// and this rect is either: bounding rect of your polygon/object to fill
// (gradient->SetCoordinateMode(TColorGradient::kObjectBoundingMode))
// or bounding rect of a pad (gradient->SetCoordinateMode(TColorGradient::kPadMode)).
// kObjectBoundingMode is the default one.
const Double_t locations[] = {0., 1.};
const Color_t idx1[] = {customRed, kOrange};
TLinearGradient * const gradFill1 = new TLinearGradient(grad1, 2, locations, idx1);
typedef TColorGradient::Point Point;
//Starting and ending points for a gradient fill (it's a vertical gradient):
gradFill1->SetStartEnd(Point(0., 0.), Point(0., 1.));
// c) Custom semi-transparent green.
new TColor(customGreen, 0., 1., 0., "green", 0.5);
// d) Gradient from ROOT's kBlue to our custom green.
const Color_t idx2[] = {customGreen, kBlue};
TLinearGradient * const gradFill2 = new TLinearGradient(grad2, 2, locations, idx2);
//Vertical gradient fill.
gradFill2->SetStartEnd(Point(0., 0), Point(0., 1.));
TH1F * const hist = new TH1F("a2", "b2", 10, -2., 3.);
TH1F * const hist2 = new TH1F("c3", "d3", 10, -3., 3.);
hist->FillRandom("landau", 100000);
hist2->FillRandom("gaus", 100000);
hist->SetFillColor(grad1);
hist2->SetFillColor(grad2);
hist2->Draw();
hist->Draw("SAME");
}
Author
Timur Pocheptsov

Definition in file grad2.C.