中心旋转

坐在悬崖上看夕阳 2010-04-07 11:05:31
CPoint pointCenter,pointA,pointB;
pointA 以 pointCenter为中心旋转角度 X 后的点 pointB是多少?

谢谢各位
...全文
84 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
我自己计算了一下,谢谢各位!
ct025028 2010-04-08
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 zhiweikongfu 的回复:]
我实验写一个:

//平移pointCenter到(0,0)点
pointA.X -= pointCenter.X;
pointA.Y -= pointCenter.Y;

//绕原点旋转pointA获得pointB的坐标
double radin = angle * 3.1415926 / 180.0; //角度转弧度
double sin = Math.……
[/Quote]

正解,将向量分解,有一个很简单的推导方法
gamedragon 2010-04-08
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 lfh001001 的回复:]
来点建设性意见。谢谢了!
[/Quote]
既然自己都知道是三角函数的问题,查一下不就好了。Google也能查出来。
whatabig 2010-04-08
  • 打赏
  • 举报
回复
#define M_PI 3.14159265358979323846
#define DegToRad(degree) ((degree) * (M_PI / 180.0f))
void MyDraw(HWND hwnd)
{
RECT device;
GetClientRect(hwnd,&device);
int cx,cy;
cx=device.right;
cy=device.bottom;

if (cx<cy)
{
cy=cx;
}
else
{
cx=cy;
}
if (cx%2)
{
cy=--cx;
}

HDC hdc;
hdc=GetDC(hwnd);

SetMapMode(hdc,MM_ANISOTROPIC);

int r=100;

// scale & xlate
SetWindowExtEx(hdc,2*r,2*r,NULL);
SetViewportExtEx(hdc,cx,-cy,NULL);

SetWindowOrgEx (hdc, 0, 0,NULL);
SetViewportOrgEx(hdc,cx/2,cy/2,NULL);

// x,y axes
MoveToEx(hdc,-r,0,NULL);
LineTo (hdc, r,0);
MoveToEx(hdc,0,r,NULL);
LineTo (hdc,0,-r);

// 100-unit circle
MoveToEx(hdc,r,0,NULL);
AngleArc(hdc,0,0,r,0,360);

// eg. for unit circle, in page space, (1,0) counter-clockwise rotate 30 degrees, becomes (cos30,sin30)
// we can calculate corresponding coordinate in device page by lptodp

POINT p;
p.x=(int)(cos(DegToRad(30)) * r);
p.y=(int)(sin(DegToRad(30)) * r);

MoveToEx(hdc,0,0,NULL);
LineTo(hdc,p.x,p.y);

// (86,49) ->( 532,146)

LPtoDP(hdc,&p,1);

}
zhiweikongfu 2010-04-07
  • 打赏
  • 举报
回复
我实验写一个:

//平移pointCenter到(0,0)点
pointA.X -= pointCenter.X;
pointA.Y -= pointCenter.Y;

//绕原点旋转pointA获得pointB的坐标
double radin = angle * 3.1415926 / 180.0; //角度转弧度
double sin = Math.Sin(radin);
double cos = Math.Cos(radin);

pointB.X = pointA.X * cos - pointA.Y * sin;
pointB.Y = pointA.X * sin + pointA.Y * cos;

//平移回去
pointB.X += pointCenter.X;
pointB.Y += pointCenter.Y;

liumenghappy 2010-04-07
  • 打赏
  • 举报
回复
乘以一个旋转矩阵就行了
Eleven 2010-04-07
  • 打赏
  • 举报
回复
数学问题
  • 打赏
  • 举报
回复
来点建设性意见。谢谢了!
gamedragon 2010-04-07
  • 打赏
  • 举报
回复
中学几何问题。
  • 打赏
  • 举报
回复
三角公式都快忘光光了,郁闷啊!

16,473

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧