1.ccpDistance函数简单介绍
函数定义:
float
ccpDistance(const CCPoint& v1, const CCPoint& v2)
{
return (v1 - v2).getLength();
}
函数作用:返回坐标V1与坐标V2之间的距离
getLength()的函数定义
inline float getLength() const {
return sqrtf(x*x + y*y); //x即为两坐标的横坐标差值,y为两坐标的纵坐标差值
};
2.计算手指与眼球的坐标距离
float dis1 = ccpDistance(location, eyeLInPos);//location即为手指当前所处位置坐标
3.根据两点间的距离来决定眼球的移动距离
1)首先我们心里要大概明白手指与眼球的距离V1与眼球移动的距离V2之间的关系,也就是两者之间的倍数,而且我们也不能拿一两个数据来决定倍数(比如:50倍-V1/50,可能手指在某些位置时眼球会随之转动,但如果位置过近,则眼球几乎是不动的),
2)根据以上分析知道,单靠两点间的距离得到的偏移量是不准确的,还需要一个值才能比较合理的得到位置偏移量,那就是触摸点的横纵坐标与眼球的初始横纵坐标之间的差值
3)通过以上的分析,最后就是确定倍数了,我们可以在程序中测出触摸最近点与触摸最远点时的V1值,我们的目的是需要最后眼球的移动距离不会因为触摸点的远近而产生很大的差距,由此就可以得到一个等式,来求出到底需要多少倍,等式如下:
D1:最近的距离
D2:最远的距离
X:需要求出的值
X/D:保证值的可用性,值的范围保证在(0.01~0.09)
X/D1*(location.x-eyeLInPos.x) = X/D2*(location.x-eyeLInPos.x)
带入工程中的值得出X≈5,进而可得出以下代码:
eyeL->setPosition(ccp(eyeLInPos.x+5/V1*(location.x-eyeLInPos.x), eyeLInPos.y+5/V1*(location.y-eyeLInPos.y)));
//5/V1:
注:记得停止触摸时将眼球归为
希望能给大家带来帮助!!!有什么问题需要讨论的可以评论私信欢迎讨论~