// Fig. 19.9: circle2.cpp // Member function definitions for class Circle #include using std::ios; using std::setiosflags; using std::setprecision; #include "circle2.h" // Constructor for Circle calls constructor for Point // with a member initializer and initializes radius Circle::Circle( double r, int a, int b ) : Point( a, b ) // call base-class constructor { setRadius( r ); } // Set radius void Circle::setRadius( double r ) { radius = ( r >= 0 ? r : 0 ); } // Get radius double Circle::getRadius() const { return radius; } // Calculate area of Circle double Circle::area() const { return 3.14159 * radius * radius; } // Output a circle in the form: // Center = [x, y]; Radius = #.## ostream &operator<<( ostream &output, const Circle &c ) { output << "Center = " << static_cast< Point > ( c ) << "; Radius = " << setiosflags( ios::fixed | ios::showpoint ) << setprecision( 2 ) << c.radius; return output; // enables cascaded calls } // end operator<< function /************************************************************************** * (C) Copyright 1992-2004 by Deitel & Associates, Inc. and * * Pearson Education, Inc. All Rights Reserved. * * * * DISCLAIMER: The authors and publisher of this book have used their * * best efforts in preparing the book. These efforts include the * * development, research, and testing of the theories and programs * * to determine their effectiveness. The authors and publisher make * * no warranty of any kind, expressed or implied, with regard to these * * programs or to the documentation contained in these books. The authors * * and publisher shall not be liable in any event for incidental or * * consequential damages in connection with, or arising out of, the * * furnishing, performance, or use of these programs. * *************************************************************************/