#include "Riostream.h"
#include "TROOT.h"
#include "TVirtualPad.h"
#include "TPolyMarker.h"
#include "TClass.h"
#include "TMath.h"
ClassImp(TPolyMarker)
TPolyMarker::TPolyMarker(): TObject()
{
fN = 0;
fX = fY = 0;
fLastPoint = -1;
}
TPolyMarker::TPolyMarker(Int_t n, Option_t *option)
:TObject(), TAttMarker()
{
fOption = option;
SetBit(kCanDelete);
fLastPoint = -1;
if (n <= 0) {
fN = 0;
fLastPoint = -1;
fX = fY = 0;
return;
}
fN = n;
fX = new Double_t [fN];
fY = new Double_t [fN];
}
TPolyMarker::TPolyMarker(Int_t n, Float_t *x, Float_t *y, Option_t *option)
:TObject(), TAttMarker()
{
fOption = option;
SetBit(kCanDelete);
fLastPoint = -1;
if (n <= 0) {
fN = 0;
fLastPoint = -1;
fX = fY = 0;
return;
}
fN = n;
fX = new Double_t [fN];
fY = new Double_t [fN];
if (!x || !y) return;
for (Int_t i=0; i<fN;i++) { fX[i] = x[i]; fY[i] = y[i]; }
fLastPoint = fN-1;
}
TPolyMarker::TPolyMarker(Int_t n, Double_t *x, Double_t *y, Option_t *option)
:TObject(), TAttMarker()
{
fOption = option;
SetBit(kCanDelete);
fLastPoint = -1;
if (n <= 0) {
fN = 0;
fLastPoint = -1;
fX = fY = 0;
return;
}
fN = n;
fX = new Double_t [fN];
fY = new Double_t [fN];
if (!x || !y) return;
for (Int_t i=0; i<fN;i++) { fX[i] = x[i]; fY[i] = y[i]; }
fLastPoint = fN-1;
}
TPolyMarker& TPolyMarker::operator=(const TPolyMarker& pm)
{
if(this!=&pm) {
TObject::operator=(pm);
TAttMarker::operator=(pm);
fN=pm.fN;
fLastPoint=pm.fLastPoint;
if (fX) delete [] fX;
if (fY) delete [] fY;
fX=pm.fX;
fY=pm.fY;
fOption=pm.fOption;
}
return *this;
}
TPolyMarker::~TPolyMarker()
{
if (fX) delete [] fX;
if (fY) delete [] fY;
fLastPoint = -1;
}
TPolyMarker::TPolyMarker(const TPolyMarker &polymarker) : TObject(polymarker), TAttMarker(polymarker)
{
fN = 0;
fX = fY = 0;
fLastPoint = -1;
((TPolyMarker&)polymarker).Copy(*this);
}
void TPolyMarker::Copy(TObject &obj) const
{
TObject::Copy(obj);
TAttMarker::Copy(((TPolyMarker&)obj));
((TPolyMarker&)obj).fN = fN;
if (((TPolyMarker&)obj).fX) delete [] (((TPolyMarker&)obj).fX);
if (((TPolyMarker&)obj).fY) delete [] (((TPolyMarker&)obj).fY);
if (fN > 0) {
((TPolyMarker&)obj).fX = new Double_t [fN];
((TPolyMarker&)obj).fY = new Double_t [fN];
for (Int_t i=0; i<fN;i++) { ((TPolyMarker&)obj).fX[i] = fX[i], ((TPolyMarker&)obj).fY[i] = fY[i]; }
} else {
((TPolyMarker&)obj).fX = 0;
((TPolyMarker&)obj).fY = 0;
}
((TPolyMarker&)obj).fOption = fOption;
((TPolyMarker&)obj).fLastPoint = fLastPoint;
}
Int_t TPolyMarker::DistancetoPrimitive(Int_t px, Int_t py)
{
const Int_t big = 9999;
Int_t i, pxp, pyp, d;
Int_t distance = big;
for (i=0;i<Size();i++) {
pxp = gPad->XtoAbsPixel(gPad->XtoPad(fX[i]));
pyp = gPad->YtoAbsPixel(gPad->YtoPad(fY[i]));
d = TMath::Abs(pxp-px) + TMath::Abs(pyp-py);
if (d < distance) distance = d;
}
return distance;
}
void TPolyMarker::Draw(Option_t *option)
{
AppendPad(option);
}
void TPolyMarker::DrawPolyMarker(Int_t n, Double_t *x, Double_t *y, Option_t *)
{
TPolyMarker *newpolymarker = new TPolyMarker(n,x,y);
TAttMarker::Copy(*newpolymarker);
newpolymarker->fOption = fOption;
newpolymarker->SetBit(kCanDelete);
newpolymarker->AppendPad();
}
void TPolyMarker::ExecuteEvent(Int_t, Int_t, Int_t)
{
}
void TPolyMarker::ls(Option_t *) const
{
TROOT::IndentLevel();
printf("TPolyMarker N=%d\n",fN);
}
Int_t TPolyMarker::Merge(TCollection *li)
{
if (!li) return 0;
TIter next(li);
TPolyMarker *pm;
Int_t npoints = 0;
while ((pm = (TPolyMarker*)next())) {
if (!pm->InheritsFrom(TPolyMarker::Class())) {
Error("Add","Attempt to add object of class: %s to a %s",pm->ClassName(),this->ClassName());
return -1;
}
npoints += pm->Size();
}
SetPoint(npoints-1,0,0);
next.Reset();
while ((pm = (TPolyMarker*)next())) {
Int_t np = pm->Size();
Double_t *x = pm->GetX();
Double_t *y = pm->GetY();
for (Int_t i=0;i<np;i++) {
SetPoint(i,x[i],y[i]);
}
}
return npoints;
}
void TPolyMarker::Paint(Option_t *option)
{
PaintPolyMarker(fLastPoint+1, fX, fY, option);
}
void TPolyMarker::PaintPolyMarker(Int_t n, Double_t *x, Double_t *y, Option_t *option)
{
if (n <= 0) return;
TAttMarker::Modify();
Double_t *xx = x;
Double_t *yy = y;
if (gPad->GetLogx()) {
xx = new Double_t[n];
for (Int_t ix=0;ix<n;ix++) xx[ix] = gPad->XtoPad(x[ix]);
}
if (gPad->GetLogy()) {
yy = new Double_t[n];
for (Int_t iy=0;iy<n;iy++) yy[iy] = gPad->YtoPad(y[iy]);
}
gPad->PaintPolyMarker(n,xx,yy,option);
if (x != xx) delete [] xx;
if (y != yy) delete [] yy;
}
void TPolyMarker::Print(Option_t *) const
{
printf("TPolyMarker N=%d\n",fN);
}
void TPolyMarker::SavePrimitive(std::ostream &out, Option_t *option )
{
char quote = '"';
out<<" "<<std::endl;
out<<" Double_t *dum = 0;"<<std::endl;
if (gROOT->ClassSaved(TPolyMarker::Class())) {
out<<" ";
} else {
out<<" TPolyMarker *";
}
out<<"pmarker = new TPolyMarker("<<fN<<",dum,dum,"<<quote<<fOption<<quote<<");"<<std::endl;
SaveMarkerAttributes(out,"pmarker",1,1,1);
for (Int_t i=0;i<Size();i++) {
out<<" pmarker->SetPoint("<<i<<","<<fX[i]<<","<<fY[i]<<");"<<std::endl;
}
out<<" pmarker->Draw("
<<quote<<option<<quote<<");"<<std::endl;
}
Int_t TPolyMarker::SetNextPoint(Double_t x, Double_t y)
{
fLastPoint++;
SetPoint(fLastPoint, x, y);
return fLastPoint;
}
void TPolyMarker::SetPoint(Int_t n, Double_t x, Double_t y)
{
if (n < 0) return;
if (!fX || !fY || n >= fN) {
Int_t newN = TMath::Max(2*fN,n+1);
Double_t *savex = new Double_t [newN];
Double_t *savey = new Double_t [newN];
if (fX && fN){
memcpy(savex,fX,fN*sizeof(Double_t));
memset(&savex[fN],0,(newN-fN)*sizeof(Double_t));
delete [] fX;
}
if (fY && fN){
memcpy(savey,fY,fN*sizeof(Double_t));
memset(&savey[fN],0,(newN-fN)*sizeof(Double_t));
delete [] fY;
}
fX = savex;
fY = savey;
fN = newN;
}
fX[n] = x;
fY[n] = y;
fLastPoint = TMath::Max(fLastPoint,n);
}
void TPolyMarker::SetPolyMarker(Int_t n)
{
if (n <= 0) {
fN = 0;
fLastPoint = -1;
delete [] fX;
delete [] fY;
fX = fY = 0;
return;
}
SetPoint(n-1,0,0);
}
void TPolyMarker::SetPolyMarker(Int_t n, Float_t *x, Float_t *y, Option_t *option)
{
if (n <= 0) {
fN = 0;
fLastPoint = -1;
delete [] fX;
delete [] fY;
fX = fY = 0;
return;
}
fN =n;
if (fX) delete [] fX;
if (fY) delete [] fY;
fX = new Double_t[fN];
fY = new Double_t[fN];
for (Int_t i=0; i<fN;i++) {
if (x) fX[i] = (Double_t)x[i];
if (y) fY[i] = (Double_t)y[i];
}
fOption = option;
fLastPoint = fN-1;
}
void TPolyMarker::SetPolyMarker(Int_t n, Double_t *x, Double_t *y, Option_t *option)
{
if (n <= 0) {
fN = 0;
fLastPoint = -1;
delete [] fX;
delete [] fY;
fX = fY = 0;
return;
}
fN =n;
if (fX) delete [] fX;
if (fY) delete [] fY;
fX = new Double_t[fN];
fY = new Double_t[fN];
for (Int_t i=0; i<fN;i++) {
if (x) fX[i] = x[i];
if (y) fY[i] = y[i];
}
fOption = option;
fLastPoint = fN-1;
}
void TPolyMarker::Streamer(TBuffer &R__b)
{
if (R__b.IsReading()) {
UInt_t R__s, R__c;
Version_t R__v = R__b.ReadVersion(&R__s, &R__c);
if (R__v > 1) {
R__b.ReadClassBuffer(TPolyMarker::Class(), this, R__v, R__s, R__c);
return;
}
TObject::Streamer(R__b);
TAttMarker::Streamer(R__b);
R__b >> fN;
fX = new Double_t[fN];
fY = new Double_t[fN];
Int_t i;
Float_t xold,yold;
for (i=0;i<fN;i++) {R__b >> xold; fX[i] = xold;}
for (i=0;i<fN;i++) {R__b >> yold; fY[i] = yold;}
fOption.Streamer(R__b);
R__b.CheckByteCount(R__s, R__c, TPolyMarker::IsA());
} else {
R__b.WriteClassBuffer(TPolyMarker::Class(),this);
}
}