This repository has been archived on 2023-05-13. You can view files and clone it, but cannot push or open issues or pull requests.
mipt_cpp/term1/seminar02_encapsulation/0circle/point.cpp

82 lines
1 KiB
C++
Raw Normal View History

2023-02-25 19:34:24 +03:00
#include <iostream>
#include <cmath>
#include "point.h"
Point::Point(float x, float y)
{
mx = x;
my = y;
}
Point::Point()
{
mx = 0;
my = 0;
}
float Point::getX() const
{
return mx;
}
float Point::getY() const
{
return my;
}
void Point::setX(float x)
{
mx = x;
}
void Point::setY(float y)
{
my = y;
}
float Point::norm() const
{
return std::sqrt(mx * mx + my * my);
}
void Point::normalize()
{
float pnorm = norm();
mx /= pnorm;
my /= pnorm;
}
float Point::distance(const Point& p) const
{
return std::sqrt((p.mx - mx) * (p.mx - mx) + (p.my - my) * (p.my - my));
}
Point Point::operator+(const Point& right) const
{
Point result = {mx + right.mx, my + right.my};
return result;
}
Point Point::operator*(float a) const
{
Point result = {a * mx, a * my};
return result;
}
Point operator*(float a, const Point& p)
{
Point result = {a * p.mx, a * p.my};
return result;
}
std::ostream& operator<<(std::ostream& left, const Point& right)
{
left << "(" << right.mx << ", " << right.my << ")";
return left;
}