主函数如下
#include"pch.h"
#include<iostream>
#include<string>
#include<opencv2/opencv.hpp>
#include<vector>
#include<algorithm>
#include"Circle.h"
#include"Point1.h"
using namespace std;
using namespace cv;
int dis;
void calculate(Point1 &p, Circle &c)
{
dis = (c.getCenter().getX() - p.getX())*(c.getCenter().getX() - (p.getX()) +
(c.getCenter().getY() - p.getY())*(p.getX()) + c.getCenter().getY() - p.getY());
if (dis == (c.getR()*c.getR()))
{
cout << "点在圆上" << endl;
}
else if (dis > (c.getR()*c.getR()))
{
cout << "点在圆外" << endl;
}
else
{
cout << "点在圆内" << endl;
}
}
void test01()
{
Circle c;
Point1 p;
Point1 center;
center.setX(20);
center.setY(7);
p.setX(10);
p.setY(10);
c.setR(10);
c.setCenter(center);
calculate(p, c);
}
int main()
{
test01();
system("pause");
return 0;
}
}
圆的.cpp文件如下
#include"pch.h"
#include"Circle.h"
#include<iostream>
using namespace std;
void Circle::setR(int r)
{
m_R = r;
}
int Circle::getR()
{
return m_R;
}
void Circle::setCenter(Point1 center)
{
m_Center = center;
}
Point1 Circle::getCenter()
{
return m_Center;
}
圆的.h文件如下
#pragma once
#include"pch.h"
#include"Point1.h"
class Circle
{
public:
void setR(int r);
int getR();
void setCenter(Point1 center);
Point1 getCenter();
private:
int m_R;
Point1 m_Center;
};
点的.h文件如下
#pragma once
#include"pch.h"
class Point1
{
public:
void setX(int x);
int getX();
void setY(int y);
int getY();
private:
int m_X;
int m_Y;
};
点的.cpp文件如下
#include"pch.h"
#include"Point1.h"
#include<iostream>
using namespace std;
void Point1::setX(int x)
{
m_X = x;
}
int Point1::getX()
{
return m_X;
}
void Point1::setY(int y)
{
m_Y = y;
}
int Point1::getY()
{
return m_Y;
}