大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处.

如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;)


免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交流之用,请勿进行商业用途。同时,转载时不要移除本申明。如产生任何纠纷,均与本博客所有人、发表该翻译稿之人无任何关系。谢谢合作!

猫咪迷宫和A*概述

正如你所看到的,现在当你在地图某处触摸的时候,猫咪将会跳到你触摸方向的相邻瓦格中去.

我们想要修改为猫咪连续移动直到你点击的位置,就像一些RPG或者点击的探险游戏一样.

让我们看一下当前触摸处理代码是如何工作的.如果你打开HelloWorldLayer,你将发现其像下面代码一样实现触摸回调:

- (void)registerWithTouchDispatcher {
    [[CCTouchDispatcher sharedDispatcher] addTargetedDelegate:self priority:0 swallowsTouches:YES];
}

- (BOOL)ccTouchBegan:(UITouch *)touch withEvent:(UIEvent *)event {

    if (_gameOver) return NO;

    CGPoint touchLocation = [_tileMap convertTouchToNodeSpace:touch];
    [_cat moveToward:touchLocation];
    return YES;
}

你可以看到它仅仅调用了cat sprite中的一个方法,让猫咪在地图上朝着触摸的点方向去移动.

所以我们将去修改CatSprite.m中的以下方法去找寻到目的点的最短路径,如下所示:

- (void)moveToward:(CGPoint)target {
    // Figure out the shortest path to the target, and start following it!
}

创建ShortestPathStep类

让我们从创建一个描述路径中的step的内部类中开始.在我们的例子中,这是一个瓦块,并且它的F,G和H分值都由A*算法来计算.

So添加以下代码到CatSprite.m的开头(在CatSprite的@implementation之上):

// A class that represents a step of the computed path
@interface ShortestPathStep : NSObject
{
    CGPoint position;
    int gScore;
    int hScore;
    ShortestPathStep *parent;
}

@property (nonatomic, assign) CGPoint position;
@property (nonatomic, assign) int gScore;
@property (nonatomic, assign) int hScore;
@property (nonatomic, assign) ShortestPathStep *parent;

- (id)initWithPosition:(CGPoint)pos;
- (int)fScore;

@end

正如你所见的,这是一个非常简单的类,其中跟踪保存了以下内容:

  • 瓦块的坐标
  • 分值G(注意,在这里是开始到当前位置的瓦片个数)
  • 分值H(注意,在这里它是当前到结束位置估计的瓦块数量)
  • ShortestPathStep来自哪里
  • 分值F,就是该瓦块的分值(用F + G来计算).

现在我们可以在CatSprite.m最后(在@end下面)写出实现代码:

@implementation ShortestPathStep

@synthesize position;
@synthesize gScore;
@synthesize hScore;
@synthesize parent;

- (id)initWithPosition:(CGPoint)pos
{
    if ((self = [super init])) {
        position = pos;
        gScore = 0;
        hScore = 0;
        parent = nil;
    }
    return self;
}

- (NSString *)description
{
    return [NSString stringWithFormat:@"%@  pos=[%.0f;%.0f]  g=%d  h=%d  f=%d", [super description], self.position.x, self.position.y, self.gScore, self.hScore, [self fScore]];
}

- (BOOL)isEqual:(ShortestPathStep *)other
{
    return CGPointEqualToPoint(self.position, other.position);
}

- (int)fScore
{
    return self.gScore + self.hScore;
}

@end

正如你看到的那样,其内容非常直截了当.我们在这里重新定义了description方法,为的是更容易去调试,并且创建了一个isEqual方法,因为2个ShortestPathStep只有在它们的posititon相同时才相同(比如:它们表示同一个瓦块).

最新文章

  1. AMD64和i386的区别
  2. 【问题与思考】1+"1"=?
  3. hdu acm steps Big Event in HDU
  4. 让PHP代码更危险----使用别的系统命令--如sql语句--exec(),system()方法甚至html的js语句
  5. Swift(三.函数)
  6. C# 队列数据结构 (三)
  7. partial 的好处
  8. 解决mac 中的myeclipse控制台中文乱码问题
  9. Storm实践
  10. js一些格式化
  11. Unity进阶----AssetBundle_03(2018/11/07)
  12. spring-mvc里的 <mvc:resources> 及静态资源访问
  13. Kafka技术内幕 读书笔记之(五) 协调者——协调者处理请求
  14. iis7下url重写后,已存在的html不能访问了(未能执行URL)的解决方法
  15. CodeForces701E DFS
  16. dubbo集群服务下一台服务挂了对服务调用的影响
  17. QQ 互联认证 回调地址提示说要http :// 但是事实不用
  18. Web通信
  19. socket概述和字节序、地址转换函数
  20. IFS二次开发03——Item

热门文章

  1. 5-15 QQ帐户的申请与登陆 (25分) HASH
  2. Tensorflow从入门到精通之——Tensorflow基本操作
  3. 使用pscp实现Windows 和 Linux 服务器间的远程拷贝文件
  4. html取地址栏参数的方法
  5. RandomAccessFile读取文本简介
  6. c++ 文件操作详解
  7. ABP文档笔记 - 规约
  8. Go 语言切片(Slice)
  9. Docker容器访问控制
  10. 安卓高级Fresco图片框架的时候