- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我几乎完成了 iPhone 应用程序的多人游戏代码,并开始着手更新 iPad 版本的图形。令我惊讶的是,在更新我的所有 Sprite 后,我的 iPad 版本的行为与 iPhone 完全不同。我正在使用由自由开发人员和 Ray Wenderlich 的 GCHelper 编写的一些自定义代码的组合。到目前为止,一切都运行良好。对于 iphone 应用程序,我的 gamelayer 发送和接收所有玩家移动。在 iPad 应用程序中,MainMenu 场景出于某种原因正在接收数据。
主菜单.h
@protocol GCHelperDelegate
- (void)matchStarted;
- (void)matchEnded;
- (void)match:(GKMatch *)match didReceiveData:(NSData *)data fromPlayer:(NSString *)playerID;
- (void)inviteReceived;
@end
@interface MainMenu: CCLayer <GCHelperDelegate>
{//some code
}
主菜单.m
- (void) StartMultiplayerGame //button calls up gamecenter matchmaking
{
NSLog(@"***In StartMultiplayerGame***");
delegate1 = (AppDelegate *) [UIApplication sharedApplication].delegate;
[[GCHelper sharedInstance] findMatchWithMinPlayers:2 maxPlayers:4 viewController:delegate1.viewController delegate:self];
boo_multiplayer=true;
boo_startgame=true;
colorLayer = [CCLayerColor layerWithColor:ccc4(0, 0, 0, 255)];
[colorLayer setOpacity:175];
[self addChild:colorLayer z:2];
return;
}
GCHelper.h
#import <Foundation/Foundation.h>
#import <GameKit/GameKit.h>
#import "cocos2d.h"
#import "AppDelegate.h"
@protocol GCHelperDelegate
- (void)matchStarted;
- (void)matchEnded;
- (void)match:(GKMatch *)match didReceiveData:(NSData *)data fromPlayer:(NSString *)playerID;
- (void)inviteReceived;
@end
@interface GCHelper : NSObject <GKMatchmakerViewControllerDelegate, GKMatchDelegate> {
BOOL gameCenterAvailable;
BOOL userAuthenticated;
bool boo_invite;
UIViewController *presentingViewController;
GKMatch *match;
BOOL matchStarted;
__strong id <GCHelperDelegate> delegate;
NSMutableDictionary *playersDict;
GKInvite *pendingInvite;
NSArray *pendingPlayersToInvite;
NSMutableArray *playernames;
NSMutableArray *playeridentification;
NSError *lastError;
GKMatchRequest *request;
// // AppDelegate *delegate1;
}
@property (assign, readonly) BOOL gameCenterAvailable;
@property (strong) UIViewController *presentingViewController;
@property (strong) GKMatch *match;
@property (strong) id <GCHelperDelegate> delegate;
@property (strong) NSMutableDictionary *playersDict;
@property (strong) GKInvite *pendingInvite;
@property (strong) NSArray *pendingPlayersToInvite;
+ (GCHelper *)sharedInstance;
- (void)authenticateLocalUser;
- (void)findMatchWithMinPlayers:(int)minPlayers maxPlayers:(int)maxPlayers viewController:(UIViewController *)viewController delegate:(id<GCHelperDelegate>)theDelegate;
@end
GCHelper.m
- (void)findMatchWithMinPlayers:(int)minPlayers maxPlayers:(int)maxPlayers viewController:(UIViewController *)viewController delegate:(id<GCHelperDelegate>)theDelegate
{
if (!gameCenterAvailable) return;
matchStarted = NO;
self.match = nil;
self.presentingViewController = viewController;
delegate = theDelegate;
if (pendingInvite != nil) {
[presentingViewController dismissModalViewControllerAnimated:NO];
GKMatchmakerViewController *mmvc = [[GKMatchmakerViewController alloc] initWithInvite:pendingInvite];
mmvc.matchmakerDelegate = self;
[presentingViewController presentModalViewController:mmvc animated:YES];
self.pendingInvite = nil;
self.pendingPlayersToInvite = nil;
}
else {
[presentingViewController dismissModalViewControllerAnimated:NO];
request=[[GKMatchRequest alloc] init];
request.minPlayers = minPlayers;
request.maxPlayers = maxPlayers;
request.playersToInvite = pendingPlayersToInvite;
GKMatchmakerViewController *mmvc = [[GKMatchmakerViewController alloc] initWithMatchRequest:request];
mmvc.matchmakerDelegate = self;
[presentingViewController presentModalViewController:mmvc animated:YES];
self.pendingInvite = nil;
self.pendingPlayersToInvite = nil;
}
}
// A peer-to-peer match has been found, the game should start
- (void)matchmakerViewController:(GKMatchmakerViewController *)viewController didFindMatch:(GKMatch *)theMatch {
[presentingViewController dismissModalViewControllerAnimated:YES];
self.match = theMatch;
self.match.delegate = self;
currentMatch=match;
if (!matchStarted && match.expectedPlayerCount == 0)
{
NSLog(@"Ready to start match!");
TXGameCenterManager * gameCenterManager = [TXGameCenterManager sharedTXGameCenterManager];
gameCenterManager.multiplayerMatch = match;
// The delegate of the match is HelloWorldLayer
gameCenterManager.multiplayerMatch.delegate = self;
AppDelegate * delegate1 = (AppDelegate *) [UIApplication sharedApplication].delegate;
[delegate1.viewController dismissModalViewControllerAnimated:NO];
[self lookupPlayers];
}
}
- (void)lookupPlayers
{
NSLog(@"Looking up %d players...", match.playerIDs.count);
[GKPlayer loadPlayersForIdentifiers:match.playerIDs withCompletionHandler:^(NSArray *players, NSError *error) {
if (error != nil) {
NSLog(@"Error retrieving player info: %@", error.localizedDescription);
matchStarted = NO;
//[delegate matchEnded];
}
else
{
// some code.
[[CCDirector sharedDirector] replaceScene:[HelloWorldLayer node]];
}
我真正不明白的是 iPad 模拟器工作得很好。我的应用程序在这里发生了什么,我如何强制 didReceiveData 方法在游戏层而不是我的菜单场景中运行?
最佳答案
真是个傻子。 iPad iOS需要升级到6.0。
关于ios - iPhone Multiplayer Code 有效,但 iPad 无效。委托(delegate)问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14866789/
我正在使用 pawn 语言开发 SAMP 服务器,但自从我开始研究 SAMP 播放器皮肤选择类以来,我就开始面临一个问题。问题是当玩家请求一个职业的所有皮肤都变暗时。 我的代码: public OnP
我正在尝试使用 javascript 制作“FourConnect”游戏。我希望有一个来自所有在线用户的列表。这个列表是我用 firebase 网站上的例子制作的。现在我希望我可以选择一个在线用户并向
对于单人游戏,Q 值更新非常直观。当前状态和 future 状态取决于单个玩家的策略,但对于两个玩家而言,情况并非如此。考虑对手获胜并且游戏终止的场景。 Q 值是如何更新的? 最佳答案 一种常见的方法
为了减少数据传输大小和为每个 worldUpdate 序列化世界对象的计算时间,我想知道是否可以省略物理可以完全、忠实地在客户端游戏引擎上模拟的对象的同步(它们不是 playerObjects所以 p
我已经开始开发一个小型多人赛车游戏,显然我们正在使用半条命、雷神之锤和虚幻引擎使用的所有玩家预测、航位推算和延迟补偿技术——但是我们计划在游戏中也有几十辆人工智能汽车. 最初我们决定简单地向所有客户端
正如标题所暗示的那样,我目前正在尝试创建一个小型多人游戏作为一个项目,只是为了更多地了解所需的所有技能。 所有这些都发生在 Java 中: 我不确定如何处理服务器通信。目前我的世界对象被保存为一个包含
我正在编写简单的游戏,我计划将多人游戏(通过网络)作为我的大学项目。我正在考虑客户端-服务器通信的两种方案: 物理(它们是微不足道的!实际上我应该称之为“碰撞测试”:))仅在服务器机器上处理。因此,通
我的游戏引擎现在由一个有效的单人游戏部分组成。我现在开始考虑如何进行多人游戏部分。 我发现很多游戏实际上并没有真正的单人模式,但是当你一个人玩的时候,你实际上也托管了一个本地服务器,几乎所有的东西都像
我已经在 unity 中工作了一段时间,并且已经通过关注 this 获得了基本的多人游戏设置。教程。但是,我想添加更多东西,其中之一是跟踪每个玩家的相机。我已经查过了,甚至找到了该教程创建者的评论。所
创建房间和自动匹配时一切正常,但问题是当我调用 p.getDisplayName() 时,在这段代码中它不返回对手名称,而是返回一些垃圾字母.. void updatePeerScores
我正在制作一款使用 GameCenter Multiplayer 的游戏,但我现在卡住了,试图弄清楚当我在模拟器上移动节点时如何让节点在我的设备上移动,反之亦然。我让 Game Center 进行身份
我正在开发一款小型多人 2d 平台游戏。我已经设法让它在网络上复制动画、移动和翻转 Sprite ,但我有一个我无法理解的错误。翻转 Sprite 的代码非常适合主持人——他可以看到其他玩家在左转或右
我正在使用适用于 Android 的 Unity 和 AllJoyn 为两人开发一种乒乓游戏。该游戏使用 Unity 的内置物理功能。我是 Unity 网络编程的新手。作为切入点,我使用了 AllJo
大家好,我是 iOS 版 Game Center 的新手。我正在尝试将使用匹配的多人游戏功能添加到我的游戏中并遵循文档。 到目前为止,我已经达到了我的 2 个客户端可以成功匹配的程度,即调用了 mat
我正在寻找一种在 Unity iOS 和 Android Basic 中使用蓝牙连接两台设备进行多人游戏的方法。我发现: AllJoyn由 Qualcomm - 蓝牙显然只适用于 Root -Andr
我创建了一个以编程方式使用实时多人游戏的游戏。它最初是针对 IOS 8 设备的。最近迁移到IOS 9后,Game Center出现了很多问题。我无法解决的主要问题是在多人游戏中邀请 friend (用
我正在使用 Google 的 TurnBasedMultiplayer API 并调用 takeTurn() 编写多人游戏。我在游戏中有三个玩家,除了调用 takeTurn 的玩家之外,我发现一个玩家
Google 于 2016 年 12 月宣布 Google+ 不再集成到 Google Play 游戏服务中:https://android-developers.googleblog.com/201
我正在实现 google play 游戏服务实时多人游戏。 目前,如果我在一个客户端上关闭 WIFI,另一个客户端不会检测到连接丢失。没有调用 PeerDisconnect 事件。 1 - API 是
我看到了 Unity 的 Multiplayer service page ,我完全糊涂了: 我可以使用Unity's high-level networking API吗? (NetworkMana
我是一名优秀的程序员,十分优秀!