2019-11-23 20:27:39 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2010 cocos2d-x.org
|
|
|
|
Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
|
|
|
|
|
2022-10-01 16:24:52 +08:00
|
|
|
https://axmolengine.github.io/
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
|
|
|
#import <UIKit/UIKit.h>
|
|
|
|
#import "AppController.h"
|
|
|
|
#import "cocos2d.h"
|
2023-06-11 13:08:08 +08:00
|
|
|
#import "platform/ios/EAGLView-ios.h"
|
2019-11-23 20:27:39 +08:00
|
|
|
#import "AppDelegate.h"
|
|
|
|
|
|
|
|
#import "RootViewController.h"
|
|
|
|
|
|
|
|
@implementation AppController
|
|
|
|
|
|
|
|
#pragma mark -
|
|
|
|
#pragma mark Application lifecycle
|
|
|
|
|
|
|
|
// cocos2d application instance
|
|
|
|
static AppDelegate s_sharedApplication;
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
- (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary*)launchOptions
|
|
|
|
{
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2022-10-18 19:17:36 +08:00
|
|
|
ax::Application* app = ax::Application::getInstance();
|
2019-11-23 20:27:39 +08:00
|
|
|
app->initGLContextAttrs();
|
2022-10-18 19:17:36 +08:00
|
|
|
ax::GLViewImpl::convertAttrs();
|
2019-11-23 20:27:39 +08:00
|
|
|
// Override point for customization after application launch.
|
|
|
|
|
|
|
|
// Add the view controller's view to the window and display.
|
2021-12-31 12:12:40 +08:00
|
|
|
window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
|
2023-08-31 17:57:19 +08:00
|
|
|
CCEAGLView* eaglView = [CCEAGLView viewWithFrame:[window bounds]
|
2022-10-18 19:17:36 +08:00
|
|
|
pixelFormat:(NSString*)ax::GLViewImpl::_pixelFormat
|
|
|
|
depthFormat:ax::GLViewImpl::_depthFormat
|
2021-12-31 12:12:40 +08:00
|
|
|
preserveBackbuffer:NO
|
|
|
|
sharegroup:nil
|
2022-10-18 19:17:36 +08:00
|
|
|
multiSampling:ax::GLViewImpl::_multisamplingCount > 0 ? YES : NO
|
|
|
|
numberOfSamples:ax::GLViewImpl::_multisamplingCount];
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2022-07-16 10:43:05 +08:00
|
|
|
#if !defined(AX_TARGET_OS_TVOS)
|
2019-11-23 20:27:39 +08:00
|
|
|
[eaglView setMultipleTouchEnabled:YES];
|
|
|
|
#endif
|
|
|
|
|
2023-08-31 17:57:19 +08:00
|
|
|
// Use RootViewController manage CCEAGLView
|
2019-11-23 20:27:39 +08:00
|
|
|
viewController = [[RootViewController alloc] initWithNibName:nil bundle:nil];
|
2022-07-16 10:43:05 +08:00
|
|
|
#if !defined(AX_TARGET_OS_TVOS)
|
2019-11-23 20:27:39 +08:00
|
|
|
viewController.wantsFullScreenLayout = YES;
|
|
|
|
#endif
|
|
|
|
viewController.view = eaglView;
|
|
|
|
|
|
|
|
// Set RootViewController to window
|
2021-12-31 12:12:40 +08:00
|
|
|
if ([[UIDevice currentDevice].systemVersion floatValue] < 6.0)
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
// warning: addSubView doesn't work on iOS6
|
2021-12-31 12:12:40 +08:00
|
|
|
[window addSubview:viewController.view];
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// use this method on ios6
|
|
|
|
[window setRootViewController:viewController];
|
|
|
|
}
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
[window makeKeyAndVisible];
|
|
|
|
|
2022-07-16 10:43:05 +08:00
|
|
|
#if !defined(AX_TARGET_OS_TVOS)
|
2021-12-31 12:12:40 +08:00
|
|
|
[[UIApplication sharedApplication] setStatusBarHidden:YES];
|
2019-11-23 20:27:39 +08:00
|
|
|
#endif
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
// Launching the app with the arguments -NSAllowsDefaultLineBreakStrategy NO to force back to the old behavior.
|
|
|
|
if ([[UIDevice currentDevice].systemVersion floatValue] >= 13.0f)
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
[[NSUserDefaults standardUserDefaults] setBool:NO forKey:@"NSAllowsDefaultLineBreakStrategy"];
|
|
|
|
}
|
|
|
|
|
|
|
|
// IMPORTANT: Setting the GLView should be done after creating the RootViewController
|
2022-10-18 19:17:36 +08:00
|
|
|
ax::GLView* glView = ax::GLViewImpl::createWithEAGLView(eaglView);
|
|
|
|
ax::Director::getInstance()->setOpenGLView(glView);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
app->run();
|
|
|
|
return YES;
|
|
|
|
}
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
- (void)applicationWillResignActive:(UIApplication*)application
|
|
|
|
{
|
2019-11-23 20:27:39 +08:00
|
|
|
/*
|
2021-12-31 12:12:40 +08:00
|
|
|
Sent when the application is about to move from active to inactive state. This can occur for certain types of
|
|
|
|
temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and
|
|
|
|
it begins the transition to the background state. Use this method to pause ongoing tasks, disable timers, and
|
|
|
|
throttle down OpenGL ES frame rates. Games should use this method to pause the game.
|
2019-11-23 20:27:39 +08:00
|
|
|
*/
|
2022-10-18 19:17:36 +08:00
|
|
|
ax::Director::getInstance()->pause();
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
- (void)applicationDidBecomeActive:(UIApplication*)application
|
|
|
|
{
|
2019-11-23 20:27:39 +08:00
|
|
|
/*
|
2021-12-31 12:12:40 +08:00
|
|
|
Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was
|
|
|
|
previously in the background, optionally refresh the user interface.
|
2019-11-23 20:27:39 +08:00
|
|
|
*/
|
2022-10-18 19:17:36 +08:00
|
|
|
ax::Director::getInstance()->resume();
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
- (void)applicationDidEnterBackground:(UIApplication*)application
|
|
|
|
{
|
2019-11-23 20:27:39 +08:00
|
|
|
/*
|
2021-12-31 12:12:40 +08:00
|
|
|
Use this method to release shared resources, save user data, invalidate timers, and store enough application state
|
|
|
|
information to restore your application to its current state in case it is terminated later. If your application
|
|
|
|
supports background execution, called instead of applicationWillTerminate: when the user quits.
|
2019-11-23 20:27:39 +08:00
|
|
|
*/
|
2022-10-18 19:17:36 +08:00
|
|
|
ax::Application::getInstance()->applicationDidEnterBackground();
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
- (void)applicationWillEnterForeground:(UIApplication*)application
|
|
|
|
{
|
2019-11-23 20:27:39 +08:00
|
|
|
/*
|
2021-12-31 12:12:40 +08:00
|
|
|
Called as part of transition from the background to the inactive state: here you can undo many of the changes made
|
|
|
|
on entering the background.
|
2019-11-23 20:27:39 +08:00
|
|
|
*/
|
2022-10-18 19:17:36 +08:00
|
|
|
ax::Application::getInstance()->applicationWillEnterForeground();
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
- (void)applicationWillTerminate:(UIApplication*)application
|
|
|
|
{
|
2019-11-23 20:27:39 +08:00
|
|
|
/*
|
|
|
|
Called when the application is about to terminate.
|
|
|
|
See also applicationDidEnterBackground:.
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
|
|
|
|
#pragma mark -
|
|
|
|
#pragma mark Memory management
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
- (void)applicationDidReceiveMemoryWarning:(UIApplication*)application
|
|
|
|
{
|
2019-11-23 20:27:39 +08:00
|
|
|
/*
|
2021-12-31 12:12:40 +08:00
|
|
|
Free up as much memory as possible by purging cached data objects that can be recreated (or reloaded from disk)
|
|
|
|
later.
|
2019-11-23 20:27:39 +08:00
|
|
|
*/
|
2022-10-18 19:17:36 +08:00
|
|
|
ax::Director::getInstance()->purgeCachedData();
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
- (void)dealloc
|
|
|
|
{
|
2019-11-23 20:27:39 +08:00
|
|
|
[super dealloc];
|
|
|
|
}
|
|
|
|
|
|
|
|
@end
|