33#include "RConfigure.h" 
   36#   define X_DISPLAY_MISSING 1 
   40#include "Windows4root.h" 
   44#   include <afterbase.h> 
   46#   include <win32/config.h> 
   47#   include <win32/afterbase.h> 
   49#   include <afterimage.h> 
   56   "ROOT palette file",  
"*.pal.root",
 
   57   "ASCII palette file", 
"*.pal.txt",
 
   62   0x0000, 0x7000, 0x0000, 0x0000, 0x0000,
 
   63   0xffff, 0xffff, 0x7000, 0x8000, 0xffff
 
   66   0x0000, 0x0000, 0x0000, 0xffff, 0xffff,
 
   67   0xffff, 0x0000, 0x0000, 0x8000, 0xffff
 
   70   0x0000, 0x7000, 0xffff, 0xffff, 0x0000,
 
   71   0x0000, 0x0000, 0x0000, 0xa000, 0xffff
 
  113   button->
SetToolTipText(
"Save the palette in a ROOT or an ASCII file");
 
  117   button->
SetToolTipText(
"Read a palette from a ROOT or an ASCII file");
 
  121   button->
SetToolTipText(
"Create a new palette (not yet implemented)");
 
  143   button->
SetToolTipText(
"Apply a log operation to the anchor points of the palette");
 
  147   button->
SetToolTipText(
"Apply a exp operation to the anchor points of the palette");
 
  151   button->
SetToolTipText(
"Make the distance of all anchor points constant");
 
  190   const ASImage *image = ((
TASImage*)attImage)->GetImage();
 
  191   if (image && image->alt.vector) {
 
  194      Int_t numPixel = image->width * image->height;
 
  195      Int_t numBins = numPixel / 20;
 
  196      numBins = (numBins < 10) ? 10 : (numBins > 200) ? 200 : numBins;
 
  200      for (pixel = 1; pixel < numPixel; pixel++) {
 
  205      fHisto = 
new TH1D(
"Statistics", 
"Pixel histogram of unzoomed image    ",
 
  207      for (pixel = 0; pixel < numPixel; pixel++)
 
  437         fprintf(fl, 
"%10.9f %04hx %04hx %04hx %04hx\n",
 
  452      gROOT->ProcessLine(
Form(
"gROOT->SaveObjectAs((TASPaletteEditor*)0x%lx,\"%s\",\"%s\");",(
ULong_t)
this,fn,
"q"));
 
  476      if (fscanf(fl, 
"%u\n", &numPoints)) {;}
 
  480         if (fscanf(fl, 
"%lf %hx %hx %hx %hx\n",
 
  504      if (dirsav) dirsav->
cd();
 
  684   numPt = 
id == 0 ? 12 : 13;
 
  709            newPalette->
fColorRed[
pt]   = 0xffff * (
pt - 1) / ((numPt - 3) / 2);
 
  716            newPalette->
fColorGreen[
pt] = 0xffff * (
pt - (numPt - 1) / 2) / ((numPt - 3) / 2);
 
  717            newPalette->
fColorBlue[
pt]  = 0xffff * (
pt - (numPt - 1) / 2) / ((numPt - 3) / 2);
 
  725            newPalette->
fColorBlue[
pt]  = 0xffff * (
pt - 1) / ((numPt - 3) / 2);
 
  729            newPalette->
fColorRed[
pt]   = 0xffff * (
pt - (numPt - 1) / 2) / ((numPt - 3) / 2);
 
  730            newPalette->
fColorGreen[
pt] = 0xffff * (
pt - (numPt - 1) / 2) / ((numPt - 3) / 2);
 
  738                                        = 0xffff * (
pt - 1) / ((numPt - 3) / 2);
 
  740                                        = 0xffff * (
pt - 1) / ((numPt - 3) / 2);
 
  742                                        = 0xffff * (
pt - 1) / ((numPt - 3) / 2);
 
  827   for (
Int_t rp = 0; rp < ramp; rp++) {
 
  882   if (newDelta < 0.001 || oldDelta < 0.001)
 
  906   grad.npoints = (*fPalette)->fNumPoints - 2;
 
  907   grad.type = GRADIENT_Left2Right;
 
  908   grad.color = 
new ARGB32[grad.npoints];
 
  909   grad.offset = 
new double[grad.npoints];
 
  911      grad.offset[
pt] = ((*fPalette)->fPoints[
pt + 1] - (*fPalette)->fPoints[1]) /
 
  912                        ((*fPalette)->fPoints[(*fPalette)->fNumPoints - 2] - (*fPalette)->fPoints[1]);
 
  913      grad.color[
pt] = (((ARGB32)((*fPalette)->fColorBlue[
pt + 1]   & 0xff00)) >>  8) |
 
  914                        (((ARGB32)((*fPalette)->fColorGreen[
pt + 1] & 0xff00))      ) |
 
  915                        (((ARGB32)((*fPalette)->fColorRed[
pt + 1]   & 0xff00)) <<  8) |
 
  916                        (((ARGB32)((*fPalette)->fColorAlpha[
pt + 1] & 0xff00)) << 16);
 
  920                                     SCL_DO_COLOR, ASA_ARGB32, 0,
 
  922   delete [] grad.color;
 
  923   delete [] grad.offset;
 
  927   destroy_asimage(&grad_im);
 
  947   fY1 = 
gPad->GetUymin();
 
  948   fY2 = 
gPad->GetUymax();
 
  970         oldX = 
gPad->XtoAbsPixel(fX1);
 
  983         fX1 = fX2 = 
gPad->AbsPixeltoX(oldX);
 
static UShort_t gRedRainbow[12]
static UShort_t gBlueRainbow[12]
static UShort_t gGreenRainbow[12]
static const char * gFileTypes[]
char * Form(const char *fmt,...)
static const ASVisual * GetVisual()
Return visual.
static void Image2Drawable(ASImage *im, Drawable_t wid, Int_t x, Int_t y, Int_t xsrc=0, Int_t ysrc=0, UInt_t wsrc=0, UInt_t hsrc=0, Option_t *opt="")
Draw asimage on drawable.
void Paint(Option_t *option)
Paint the limit lines.
LimitLine(Coord_t x, Coord_t y1, Coord_t y2, TASPaletteEditor *gui)
The blue limit line in the pixel value histogram.
virtual void ExecuteEvent(Int_t event, Int_t px, Int_t py)
Execute action corresponding to one event.
void Paint(Option_t *option)
Actually paint the paletter.
This is a GUI window to edit a color palette.
void UpdateScreen(Bool_t histoUpdate)
All widgets of the screen are updated with the current palette.
PaintPalette * fPaintPalette
void UpdateRange()
Updates the range of the palette.
TGTextButton * fUnDoButton
TImagePalette * fPalette
current palette
void CloseWindow()
Close editor.
TGCheckButton * fStepButton
TGTextButton * fReDoButton
Double_t fMinValue
min value of image
void Open()
Opens either a ROOT file or an ASCII file and reads a palette.
TList * fPaletteList
list of palettes for undo and redo
void ExpPalette()
The anchor points are rescaled by a exp operation.
void InsertNewPalette(TImagePalette *newPalette)
The newPalette is inserted in the list of palettes (fPaletteList) and fPalette is set to the newPalet...
TGRadioButton * fRamps[3]
TASPaletteEditor(TAttImage *attImage, UInt_t w, UInt_t h)
Palette editor constructor.
TRootEmbeddedCanvas * fHistCanvas
canvas to draw the histogram
TH1D * fHisto
histogram of image pixels
void Save()
Saves the current palette either into a ROOT file or in an ASCII file.
TGCheckButton * fAutoUpdate
virtual ~TASPaletteEditor()
Palette editor destructor. Deletes all frames and their layout hints.
void NewPalette(Long_t id)
A new palette is created, depending on the id.
void LinPalette()
The anchor points are rescaled to be linar.
LimitLine * fLimitLine[2]
void SetRamp(Long_t ramp)
The palette is repeated up to 4 times.
Bool_t ProcessMessage(Long_t msg, Long_t param1, Long_t param2)
Process all editor mouse events.
void InvertPalette()
The palette is inverted.
void SetStep()
Create a step palette.
Double_t fMaxValue
max value of image
void LogPalette()
The anchor points are rescaled by a log operation.
TRootEmbeddedCanvas * fPaletteCanvas
canvas to draw the current palette
virtual void SetLabelSize(Float_t size=0.04)
Set size of axis labels The size is expressed in per cent of the pad width.
virtual void SetLabelFont(Style_t font=62)
Set labels' font.
virtual void SetPalette(const TImagePalette *palette)
Set a new palette for the image.
EImageQuality GetImageQuality() const
virtual const TImagePalette & GetPalette() const
virtual void SetLineWidth(Width_t lwidth)
Set the line width.
virtual void SetLineColor(Color_t lcolor)
Set the line color.
virtual void Modify()
Change current line attributes if necessary.
virtual void Update()
Update canvas pad buffers.
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
virtual TObject * Get(const char *namecycle)
Return pointer to object identified by namecycle.
Describe directory structure in memory.
virtual Bool_t cd(const char *path=0)
Change current directory to "this" directory.
A ROOT file is a suite of consecutive data records (TKey instances) with a well defined format.
virtual Bool_t IsOpen() const
Returns kTRUE in case file is open and kFALSE if file is not open.
virtual void AddEntry(TGString *s, Int_t id)
virtual void Select(Int_t id, Bool_t emit=kTRUE)
Make the selected item visible in the combo box window and emit signals according to the second param...
virtual void SetLayoutManager(TGLayoutManager *l)
Set the layout manager for the composite frame.
virtual void AddFrame(TGFrame *f, TGLayoutHints *l=0)
Add frame to the composite frame using the specified layout hints.
virtual void Layout()
Layout the elements of the composite frame.
virtual void MapSubwindows()
Map all sub windows that are part of the composite frame.
void SetIconName(const char *name)
Set window icon name. This is typically done via the window manager.
void SetWindowName(const char *name=0)
Set window name. This is typically done via the window manager.
1-D histogram with a double per channel (see TH1 documentation)}
TAxis * GetXaxis()
Get the behaviour adopted by the object about the statoverflows. See EStatOverflows for more informat...
virtual Double_t GetMaximum(Double_t maxval=FLT_MAX) const
Return maximum value smaller than maxval of bins in the range, unless the value has been overridden b...
virtual Int_t Fill(Double_t x)
Increment bin with abscissa X by 1.
virtual void Draw(Option_t *option="")
Draw this histogram with options.
A class to define a conversion from pixel values to pixel color.
UShort_t * fColorRed
[fNumPoints] red color at each anchor point
Double_t * fPoints
[fNumPoints] value of each anchor point [0..1]
UShort_t * fColorGreen
[fNumPoints] green color at each anchor point
UShort_t * fColorBlue
[fNumPoints] blue color at each anchor point
UInt_t fNumPoints
number of anchor points
UShort_t * fColorAlpha
[fNumPoints] alpha at each anchor point
virtual void SetX2(Double_t x2)
virtual void SetX1(Double_t x1)
virtual void Paint(Option_t *option="")
Paint this line with its current attributes.
virtual void Add(TObject *obj)
virtual TObject * After(const TObject *obj) const
Returns the object after object obj.
virtual TObject * Remove(TObject *obj)
Remove object from the list.
virtual TObject * Last() const
Return the last object in the list. Returns 0 when list is empty.
virtual TObject * Before(const TObject *obj) const
Returns the object before object obj.
virtual TObject * First() const
Return the first object in the list. Returns 0 when list is empty.
Mother of all ROOT objects.
virtual void Draw(Option_t *option="")
Default Draw method for all objects.
void Modified(Bool_t flag=1)
Edit the palette via a GUI.
virtual void CloseWindow()
Closes the window and deletes itself.
TCanvas * GetCanvas() const
virtual void Modified(Bool_t flag=1)=0