TrackDataScrap.cc
上传用户:weiliju62
上传日期:2007-01-06
资源大小:619k
文件大小:3k
源码类别:

SCSI/ASPI

开发平台:

MultiPlatform

  1. /*  cdrdao - write audio CD-Rs in disc-at-once mode
  2.  *
  3.  *  Copyright (C) 1998, 1999 Andreas Mueller <mueller@daneb.ping.de>
  4.  *
  5.  *  This program is free software; you can redistribute it and/or modify
  6.  *  it under the terms of the GNU General Public License as published by
  7.  *  the Free Software Foundation; either version 2 of the License, or
  8.  *  (at your option) any later version.
  9.  *
  10.  *  This program is distributed in the hope that it will be useful,
  11.  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
  12.  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  13.  *  GNU General Public License for more details.
  14.  *
  15.  *  You should have received a copy of the GNU General Public License
  16.  *  along with this program; if not, write to the Free Software
  17.  *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  18.  */
  19. /*
  20.  * $Log: TrackDataScrap.cc,v $
  21.  * Revision 1.1  1999/08/27 18:40:01  mueller
  22.  * Initial revision
  23.  *
  24.  */
  25. static char rcsid[] = "$Id: TrackDataScrap.cc,v 1.1 1999/08/27 18:40:01 mueller Exp $";
  26. #include "TrackDataScrap.h"
  27. #include <stddef.h>
  28. #include "util.h"
  29. #include "TrackData.h"
  30. #include "TrackDataList.h"
  31. TrackDataScrap::TrackDataScrap(TrackDataList *l)
  32. {
  33.   list_ = l;
  34.   blocks_ = 0;
  35.   leftNegSamples_ = NULL;
  36.   leftPosSamples_ = NULL;
  37.   rightNegSamples_ = NULL;
  38.   rightPosSamples_ = NULL;
  39. }
  40. TrackDataScrap::~TrackDataScrap()
  41. {
  42.   delete list_;
  43.   list_ = NULL;
  44.   delete[] leftNegSamples_;
  45.   leftNegSamples_ = NULL;
  46.   delete[] leftPosSamples_;
  47.   leftPosSamples_ = NULL;
  48.   delete[] rightNegSamples_;
  49.   rightNegSamples_ = NULL;
  50.   delete[] rightPosSamples_;
  51.   rightPosSamples_ = NULL;
  52. }
  53. const TrackDataList *TrackDataScrap::trackDataList() const
  54. {
  55.   return (const TrackDataList*)list_;
  56. }
  57. void TrackDataScrap::setPeaks(long blocks,
  58.       short *leftNegSamples, short *leftPosSamples,
  59.       short *rightNegSamples, short *rightPosSamples)
  60. {
  61.   long i;
  62.   blocks_ = blocks;
  63.   delete[] leftNegSamples_;
  64.   delete[] leftPosSamples_;
  65.   delete[] rightNegSamples_;
  66.   delete[] rightPosSamples_;
  67.   if (blocks > 0) {
  68.     leftNegSamples_ = new short[blocks];
  69.     leftPosSamples_ = new short[blocks];
  70.     rightNegSamples_ = new short[blocks];
  71.     rightPosSamples_ = new short[blocks];
  72.     for (i = 0; i < blocks; i++) {
  73.       leftNegSamples_[i] = leftNegSamples[i];
  74.       leftPosSamples_[i] = leftPosSamples[i];
  75.       rightNegSamples_[i] = rightNegSamples[i];
  76.       rightPosSamples_[i] = rightPosSamples[i];
  77.     }
  78.   }
  79.   else {
  80.     leftNegSamples_ = NULL;
  81.     leftPosSamples_ = NULL;
  82.     rightNegSamples_ = NULL;
  83.     rightPosSamples_ = NULL;
  84.   }    
  85. }
  86. void TrackDataScrap::getPeaks(long blocks, short *leftNegSamples,
  87.       short *leftPosSamples, short *rightNegSamples,
  88.       short *rightPosSamples) const
  89. {
  90.   long n, i;
  91.   if (leftNegSamples_ == NULL)
  92.     return;
  93.   n = (blocks_ < blocks) ? blocks_ : blocks;
  94.   
  95.   for (i = 0; i < n; i++) {
  96.     leftNegSamples[i] = leftNegSamples_[i];
  97.     leftPosSamples[i] = leftPosSamples_[i];
  98.     rightNegSamples[i] = rightNegSamples_[i];
  99.     rightPosSamples[i] = rightPosSamples_[i];
  100.   }
  101. }