道歉,如果这是重复的,我的谷歌弱。
我的代码中有两种方法路由选项:
使用调用一堆对象属性的本地方法:
/* public class Manager */
public void onTouchEvent( Event event )
{
Vec2 touch = new Vec2( event.getX(), event.getY() );
for( GameObject o : mGameObjectList )
{
if ( isColliding( touch, o ) )
o.onTouchEvent(event);
}
}
public boolean isColliding( Vec2 touch, GameObject obj )
{
if ( ( obj.mPosition[ 0 ] - obj.mScale[ 0 ] ) < touch.x && touch.x < ( obj.mPosition[ 0 ] + obj.mScale[ 0 ] ) )
{
if ( ( obj.mPosition[ 1 ] - obj.mScale[ 1 ] ) < touch.y && touch.y < ( obj.mPosition[ 1 ] + obj.mScale[ 1 ] ) )
{
return true;
}
}
return false;
}
调用一个对象方法,然后使用本地属性:
/* public class Manager */
public void onTouchEvent( Event event )
{
for( GameObject o : mGameObjectList )
{
o.isColliding(event);
}
}
/* public class GameObject */
public boolean isColliding( Event event )
{
// code here to get touch from event ( or maybe pass in touch? )
if ( ( mPosition[ 0 ] - mScale[ 0 ] ) < touch.x && touch.x < mPosition[ 0 ] + ( mScale[ 0 ] ) )
{
if ( ( mPosition[ 1 ] - mScale[ 1 ] ) < touch.y && touch.y < mPosition[ 1 ] + ( mScale[ 1 ] ) )
{
onTouchEvent(event)
}
}
return false;
}
哪种方法可以更好地以编程方式(最佳,优雅,简单等)?
更新:固定代码部分。对此感到抱歉。
答案 0 :(得分:2)
我会用GameObject::containsPoint(x, y)
方法来写这个。这样,它不需要了解触摸事件,但您的触摸类也不需要了解计算交叉点。
我是这样做的。
/* class GameObject */
public boolean contains(int x, int y)
{
//Your use of parentheses here was really confusing!
return mPosition[0] - mScale[0] < x && x < mPosition[0] + mScale[0]
&& mPosition[1] - mScale[1] < y && y < mPosition[1] + mScale[1];
/* alternatively:
return Math.abs(x - mPosition[0]) < mScale[0]
&& Math.abs(y - mPosition[1]) < mScale[1];
*/
}
/* class Manager */
public void onTouchEvent( Event event )
{
for( GameObject o : mGameObjectList )
{
if(o.contains(event.getX(), event.getY()))
{
o.onTouchEvent(event);
}
}
}
我不确定转换为Vec2
是否有效(或一致)。为什么触摸点被提升为Vec2
,但GameObject::mPosition
是一个数组?