/* MetaContour, version 0.1 -------------------------------------- */
/* Copyright(C) 2004, Brooks Moses                                 */
/*                                                                 */
/* This version of MetaContour is made available under the Gnu     */
/* Public License; see metacontour_main.cc for details.            */
/*                                                                 */
/* This is a very pre-release version of MetaContour, distributed  */
/* primarily as an example of a use of MetaPlot.  It can be        */
/* compiled with gcc using the line:                               */
/*                                                                 */
/*   g++ metacontour.cc cpoint.cc metacontour_main.cc              */
/*                                                                 */
/*-----------------------------------------------------------------*/

/* Class containing Metapost contour plot streams */

#include<string>
#include<sstream>
#include<vector>
#include"cpoint.h"

class MetapostContours {

  ostringstream GridStream;
  ostringstream FillPlotStream;
  ostringstream LinePlotStream;

  vector<double> ContourList;

  void PlotSquare (cpoint, cpoint, cpoint, cpoint);
  void PlotCorner (cpoint, cpoint, cpoint, cpoint, int);
  void PlotRect   (cpoint, cpoint, cpoint, cpoint, int);
  void PlotPent   (cpoint, cpoint, cpoint, cpoint, int);
  void PlotHex    (cpoint, cpoint, cpoint, cpoint, int, double);

  void DrawFilled (int, cpoint, cpoint, cpoint);
  void DrawFilled (int, cpoint, cpoint, cpoint, cpoint);
  void DrawFilled (int, cpoint, cpoint, cpoint, cpoint, cpoint);
  void DrawFilled (int, cpoint, cpoint, cpoint, cpoint, cpoint, cpoint);
  void DrawLine   (int, cpoint, cpoint);
  void DrawGrid   (cpoint, cpoint);
  
  string PlotName;
  string GridCommand;
  string DrawCommand;
  string FillCommand;
  
public:
  MetapostContours(cparray&, vector<double>&, string&);

  string Grid() const { return GridStream.str(); }
  string FillPlot() const { return FillPlotStream.str(); }
  string LinePlot() const { return LinePlotStream.str(); }

  vector<double> ContourListOut() const { return ContourList; }
  
};