diff --git a/ContentExtension/Info.plist b/ContentExtension/Info.plist index 95ccb76..2e2b277 100644 --- a/ContentExtension/Info.plist +++ b/ContentExtension/Info.plist @@ -17,9 +17,9 @@ CFBundlePackageType XPC! CFBundleShortVersionString - 1.2.6 + 1.2.7 CFBundleVersion - 12 + 2 NSExtension NSExtensionAttributes diff --git a/General/AppDelegate.swift b/General/AppDelegate.swift index cbb125f..0af3f4e 100755 --- a/General/AppDelegate.swift +++ b/General/AppDelegate.swift @@ -28,6 +28,7 @@ class AppDelegate: UIResponder, UIApplicationDelegate { @objc var currentUnityController: UnityAppController? var isUnityRunning = false var application: UIApplication? + var enableAllOrientation = true func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool { self.application = application @@ -105,24 +106,6 @@ class AppDelegate: UIResponder, UIApplicationDelegate { func applicationWillEnterForeground(_ application: UIApplication) { // Called as part of the transition from the background to the active state; here you can undo many of the changes made on entering the background. // let _ = ThemeManager.init() - let interval = Date().timeIntervalSince1970 - time - if(isLaunched){ - if(!isOn && interval >= 60){ - if let controller = UIStoryboard(name: "Main", bundle: nil).instantiateInitialViewController() as? LaunchScreenViewController { - if let window = self.window, let rootViewController = window.rootViewController { - var currentController = rootViewController - while let presentedController = currentController.presentedViewController { - currentController = presentedController - } - if !((currentController as? UINavigationController)?.topViewController is QLPreviewController) { - currentController.present(controller, animated: true, completion: nil) - } - } - } - } - } else { - isLaunched = true - } } @@ -171,6 +154,12 @@ class AppDelegate: UIResponder, UIApplicationDelegate { isUnityRunning = false } } + + func resetUnity() { + unity_init(CommandLine.argc, CommandLine.unsafeArgv) + currentUnityController = UnityAppController() + currentUnityController!.application(application!, didFinishLaunchingWithOptions: nil) + } } diff --git a/General/Base.lproj/Main.storyboard b/General/Base.lproj/Main.storyboard index b1c504a..5a23637 100755 --- a/General/Base.lproj/Main.storyboard +++ b/General/Base.lproj/Main.storyboard @@ -606,24 +606,6 @@ Cache - - - - - - - - - - - - - - - - - - @@ -665,6 +647,7 @@ Cache + @@ -962,7 +945,7 @@ Cache - + @@ -1123,7 +1106,6 @@ Cache - @@ -1301,37 +1283,6 @@ Cache - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/General/GameCenterView.swift b/General/GameCenterView.swift index b4b6d71..120a33a 100644 --- a/General/GameCenterView.swift +++ b/General/GameCenterView.swift @@ -18,7 +18,7 @@ class GameCenterViewController:UITableViewController{ var descriptions = [String]() var urls = [String]() var images = [String]() - + var in_url:String? = nil func loadFromLocal(){ @@ -49,16 +49,19 @@ class GameCenterViewController:UITableViewController{ Alamofire.request("https://api.nfls.io/game/list").responseJSON { response in switch(response.result){ case .success(let json): - let info = ((json as! [String:AnyObject])["info"] as! [[String:Any]]) self.names.removeAll() self.descriptions.removeAll() self.urls.removeAll() self.images.removeAll() + var index:Int? = nil for detail in info { self.names.append(detail["name"] as! String) self.descriptions.append(detail["description"] as! String) self.urls.append(detail["url"] as! String) + if self.urls.last == self.in_url { + index = self.names.count - 1 + } self.images.append(detail["icon"] as! String) } UserDefaults.standard.set(self.names, forKey: "game_names") @@ -69,6 +72,13 @@ class GameCenterViewController:UITableViewController{ DispatchQueue.main.asyncAfter(deadline: .now() + 2.0, execute: { self.tableView.reloadData() }) + if let index = index { + if self.urls[index] == "unity" { + self.performSegue(withIdentifier: "showUnity", sender: index) + } else { + self.performSegue(withIdentifier: "showGame", sender: index) + } + } break default: break @@ -109,24 +119,31 @@ class GameCenterViewController:UITableViewController{ cell.detailTextLabel!.font = UIFont(name: "Helvetica", size: 14) cell.imageView?.kf.setImage(with: URL(string: images[indexPath.row]), placeholder: nil, options: nil, progressBlock: nil, completionHandler: { (image, _, _, _) in DispatchQueue.main.async { - cell.imageView?.image = image!.kf.resize(to: CGSize(width: 75, height: 75)) + if let image = image { + cell.imageView?.image = image.kf.resize(to: CGSize(width: 75, height: 75)) + } } - }) return cell } override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) { - self.performSegue(withIdentifier: "showGame", sender: indexPath.row) + if urls[indexPath.row] == "unity" { + self.performSegue(withIdentifier: "showUnity", sender: indexPath.row) + } else { + self.performSegue(withIdentifier: "showGame", sender: indexPath.row) + } } override func prepare(for segue: UIStoryboardSegue, sender: Any?) { - let index = sender as! Int - let dest = segue.destination as! GameViewController - dest.location = urls[index] - dest.name = names[index] - dest.id = index + 1 + if segue.destination is GameViewController { + let index = sender as! Int + let dest = segue.destination as! GameViewController + dest.location = urls[index] + dest.name = names[index] + dest.id = index + 1 + } } override func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat { return 75 diff --git a/General/InAppSettings.bundle/Authors.plist b/General/InAppSettings.bundle/Authors.plist index 4095f97..9e9bbee 100644 --- a/General/InAppSettings.bundle/Authors.plist +++ b/General/InAppSettings.bundle/Authors.plist @@ -164,22 +164,6 @@ Key - - Type - PSGroupSpecifier - Title - Secret Zone - Key - - - - Type - PSTextFieldSpecifier - Title - - Key - app.code - diff --git a/General/InAppSettings.bundle/Root.plist b/General/InAppSettings.bundle/Root.plist index 65e7fb3..e566577 100644 --- a/General/InAppSettings.bundle/Root.plist +++ b/General/InAppSettings.bundle/Root.plist @@ -160,14 +160,6 @@ File Authors - - Type - PSChildPaneSpecifier - Title - 管理 - File - Management - diff --git a/General/Info.plist b/General/Info.plist index 0e6ed88..29b698d 100755 --- a/General/Info.plist +++ b/General/Info.plist @@ -17,13 +17,13 @@ CFBundlePackageType APPL CFBundleShortVersionString - 1.2.6 + 1.2.7 CFBundleVersion - 12 + 2 CodeNameCN - ドライクリーク + 決別 CodeNameEN - Arroyo + Farewell ITSAppUsesNonExemptEncryption LSRequiresIPhoneOS diff --git a/General/NewsView.swift b/General/NewsView.swift index a64ecc9..da6c57a 100644 --- a/General/NewsView.swift +++ b/General/NewsView.swift @@ -40,7 +40,7 @@ class NewsViewController:UITableViewController,FrostedSidebarDelegate{ )) required init?(coder aDecoder: NSCoder) { - let images = ["resources","game","photo","alumni","ic","forum","wiki","media","weather"] + let images = ["resources","game"/*,"photo"*/,"alumni","ic","forum","wiki","media","weather"] var barImages = [UIImage]() for image in images{ barImages.append(UIImage(named: image+".png")!) @@ -58,26 +58,24 @@ class NewsViewController:UITableViewController,FrostedSidebarDelegate{ self.performSegue(withIdentifier: "showGame", sender: self) } self.bar.actionForIndex[2] = { - self.performSegue(withIdentifier: "showPhoto", sender: self) - } - self.bar.actionForIndex[3] = { self.performSegue(withIdentifier: "showAlumni", sender: self) } - self.bar.actionForIndex[4] = { + self.bar.actionForIndex[3] = { self.performSegue(withIdentifier: "showIC", sender: self) } - self.bar.actionForIndex[5] = { + self.bar.actionForIndex[4] = { self.performSegue(withIdentifier: "showForum", sender: self) } - self.bar.actionForIndex[6] = { + self.bar.actionForIndex[5] = { self.performSegue(withIdentifier: "showWiki", sender: self) } - self.bar.actionForIndex[7] = { + self.bar.actionForIndex[6] = { self.performSegue(withIdentifier: "showMedia", sender: self) } - self.bar.actionForIndex[8] = { + self.bar.actionForIndex[7] = { self.performSegue(withIdentifier: "showWeather", sender: self) } + //self.bar.actionForIndex.removeValue(forKey: 2) self.bar.delegate = self @@ -106,7 +104,7 @@ class NewsViewController:UITableViewController,FrostedSidebarDelegate{ Alamofire.request("https://api.nfls.io/weather/ping") checkStatus() self.removeFile(filename: "", path: "temp") - let rightButton = UIBarButtonItem(title: nil, style: .plain, target: self, action: #selector(self.showUnity)) + let rightButton = UIBarButtonItem(title: nil, style: .plain, target: self, action: #selector(self.settings)) rightButton.icon(from: .FontAwesome, code: "cog", ofSize: 20) self.navigationItem.rightBarButtonItem = rightButton let leftButton = UIBarButtonItem(title: nil, style: .plain, target: self, action: #selector(self.menu)) @@ -122,9 +120,7 @@ class NewsViewController:UITableViewController,FrostedSidebarDelegate{ view.addGestureRecognizer(swipeBack) } - @objc func showUnity() { - self.performSegue(withIdentifier: "showUnity", sender: self) - } + @objc func refresh() { loadNews() debugPrint("refresh") @@ -458,7 +454,7 @@ class NewsViewController:UITableViewController,FrostedSidebarDelegate{ self.performSegue(withIdentifier: "showWeather", sender: self) break case "game": - self.performSegue(withIdentifier: "showGame", sender: self) + self.performSegue(withIdentifier: "showGame", sender: in_url) break default: if let url = realurl{ @@ -489,6 +485,11 @@ class NewsViewController:UITableViewController,FrostedSidebarDelegate{ if(sender as? String != nil){ dest.in_url = sender as! String } + } else if (segue.identifier == "showGame") { + let dest = segue.destination as! GameCenterViewController + if(sender as? String != nil){ + dest.in_url = sender as! String + } } } diff --git a/General/ResourcesFiltringView.swift b/General/ResourcesFiltringView.swift index c0c1c1d..bbf5a0c 100644 --- a/General/ResourcesFiltringView.swift +++ b/General/ResourcesFiltringView.swift @@ -212,7 +212,7 @@ class ResourcesFiltringViewController:UIViewController, UITableViewDataSource, U response in switch response.result{ case .success(let json): - + self.files.removeAll() let data = (json as! [String:AnyObject])["items"]! as! NSArray for file in data{ var name = (file as! [String:Any])["href"] as! String @@ -279,7 +279,7 @@ class ResourcesFiltringViewController:UIViewController, UITableViewDataSource, U } } func checkForYear(){ - if(!UserDefaults.standard.bool(forKey: "ettings.resources.rank")){ + if(!UserDefaults.standard.bool(forKey: "settings.resources.rank")){ for file in files{ if(file.filename.contains("2016")){ files.reverse() diff --git a/General/UnityView.swift b/General/UnityView.swift index 6c4f4fb..4d05901 100644 --- a/General/UnityView.swift +++ b/General/UnityView.swift @@ -11,19 +11,54 @@ import UIKit class UnityViewController:UIViewController { var unityView: UIView? + var isRunning = false override func viewDidLoad() { - let appDelegate = UIApplication.shared.delegate as! AppDelegate - appDelegate.startUnity() - + self.title = "Christmas Carol" unityView = UnityGetGLView()! - - self.view!.addSubview(unityView!) + self.view.addSubview(unityView!) unityView!.translatesAutoresizingMaskIntoConstraints = false - + self.view!.backgroundColor = UIColor.black // look, non-full screen unity content! - let views = ["view": unityView] - let w = NSLayoutConstraint.constraints(withVisualFormat: "|-20-[view]-20-|", options: [], metrics: nil, views: views) - let h = NSLayoutConstraint.constraints(withVisualFormat: "V:|-75-[view]-50-|", options: [], metrics: nil, views: views) + let views = ["view": unityView!] + let w = NSLayoutConstraint.constraints(withVisualFormat: "|-[view]-|", options: [], metrics: nil, views: views) + let h = NSLayoutConstraint.constraints(withVisualFormat: "V:|-[view]-|", options: [], metrics: nil, views: views) view.addConstraints(w + h) + //let res = UIBarButtonItem(barButtonSystemItem: .refresh, target: self, action: #selector(reset)) + //self.navigationItem.rightBarButtonItem = res + } + @objc func reset() { + let appDelegate = UIApplication.shared.delegate as! AppDelegate + + appDelegate.stopUnity() + appDelegate.resetUnity() + appDelegate.startUnity() + } + override func viewDidAppear(_ animated: Bool) { + if isRunning { + let appDelegate = UIApplication.shared.delegate as! AppDelegate + + appDelegate.startUnity() + } else { + isRunning = true + let alert = UIAlertController(title: "温馨提醒", message: "此消息将在3秒后自动消失\n1.佩戴耳机获得更佳食用效果\n2.建议在竖屏模式下食用\n3.重置游戏需要后台完全关闭App\n4.如果有任何BUG,请联系游戏开发者谢祖地\nBy:胡清阳", preferredStyle: .alert) + (alert.view.subviews[0].subviews[0].subviews[0].subviews[0].subviews[0].subviews[1] as! UILabel).textAlignment = .left + self.present(alert, animated: true) { + DispatchQueue.main.asyncAfter(deadline: .now() + 3.0, execute: { + alert.dismiss(animated: true, completion: { + let appDelegate = UIApplication.shared.delegate as! AppDelegate + appDelegate.startUnity() + }) + }) + } + } + } + + override func viewDidDisappear(_ animated: Bool) { + let appDelegate = UIApplication.shared.delegate as! AppDelegate + appDelegate.stopUnity() + unityView!.removeFromSuperview() + } + + } diff --git a/General/WeatherView.swift b/General/WeatherView.swift index d1f78cc..b45d68e 100644 --- a/General/WeatherView.swift +++ b/General/WeatherView.swift @@ -133,7 +133,7 @@ class WeatherViewController:UIViewController,UITableViewDataSource,UITableViewDe default: key = stations[indexPath.section].data[indexPath.row - 4]["name"] value = stations[indexPath.section].data[indexPath.row - 4]["value"] - cell.accessoryType = .disclosureIndicator + cell.accessoryType = .none } cell.textLabel!.text = key @@ -161,7 +161,7 @@ class WeatherViewController:UIViewController,UITableViewDataSource,UITableViewDe let latitude = stations[indexPath.section].latitude self.performSegue(withIdentifier: "showMap", sender: [longitude,latitude]) default: - self.showHistoryData(indexPath: indexPath) + //self.showHistoryData(indexPath: indexPath) break } return diff --git a/NFLSers-iOS.xcodeproj/project.pbxproj b/NFLSers-iOS.xcodeproj/project.pbxproj index f770eb0..a9ff909 100644 --- a/NFLSers-iOS.xcodeproj/project.pbxproj +++ b/NFLSers-iOS.xcodeproj/project.pbxproj @@ -1208,6 +1208,7 @@ E5BC3AD96A01BCEAF78DDDCA /* [CP] Check Pods Manifest.lock */, D6AE173A1E44D51600E66B4B /* Sources */, D6AE173B1E44D51600E66B4B /* Frameworks */, + 65BFCD831FE825D100821ABD /* ShellScript */, D6AE173C1E44D51600E66B4B /* Resources */, 22E64A7FDA9057C2741B7323 /* [CP] Embed Pods Frameworks */, 6B93F9D0123AA7825650D41B /* [CP] Copy Pods Resources */, @@ -1430,6 +1431,19 @@ shellScript = "\"${SRCROOT}/Pods/Target Support Files/Pods-NFLSers-iOS/Pods-NFLSers-iOS-frameworks.sh\"\n"; showEnvVarsInLog = 0; }; + 65BFCD831FE825D100821ABD /* ShellScript */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputPaths = ( + ); + outputPaths = ( + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "rm -rf \"$TARGET_BUILD_DIR/$PRODUCT_NAME.app/Data\";\ncp -Rf \"$UNITY_IOS_EXPORT_PATH/Data\" \"$TARGET_BUILD_DIR/$PRODUCT_NAME.app/Data\";"; + }; 6B93F9D0123AA7825650D41B /* [CP] Copy Pods Resources */ = { isa = PBXShellScriptBuildPhase; buildActionMask = 2147483647; @@ -1685,7 +1699,7 @@ CODE_SIGN_IDENTITY = "iPhone Developer"; "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 12; + CURRENT_PROJECT_VERSION = 15; DEVELOPMENT_TEAM = K2P3533G4D; GCC_C_LANGUAGE_STANDARD = gnu11; INFOPLIST_FILE = ContentExtension/Info.plist; @@ -1709,7 +1723,7 @@ CODE_SIGN_IDENTITY = "iPhone Developer"; "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 12; + CURRENT_PROJECT_VERSION = 15; DEVELOPMENT_TEAM = K2P3533G4D; GCC_C_LANGUAGE_STANDARD = gnu11; INFOPLIST_FILE = ContentExtension/Info.plist; @@ -1733,7 +1747,7 @@ CODE_SIGN_IDENTITY = "iPhone Developer"; "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 12; + CURRENT_PROJECT_VERSION = 15; DEVELOPMENT_TEAM = K2P3533G4D; GCC_C_LANGUAGE_STANDARD = gnu11; INFOPLIST_FILE = pushNotification/Info.plist; @@ -1757,7 +1771,7 @@ CODE_SIGN_IDENTITY = "iPhone Developer"; "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 12; + CURRENT_PROJECT_VERSION = 15; DEVELOPMENT_TEAM = K2P3533G4D; GCC_C_LANGUAGE_STANDARD = gnu11; INFOPLIST_FILE = pushNotification/Info.plist; @@ -1888,7 +1902,7 @@ CODE_SIGN_ENTITLEMENTS = "NFLSers-iOS.entitlements"; CODE_SIGN_IDENTITY = "iPhone Developer"; "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; - CURRENT_PROJECT_VERSION = 12; + CURRENT_PROJECT_VERSION = 15; DEVELOPMENT_TEAM = K2P3533G4D; FRAMEWORK_SEARCH_PATHS = ( "$(inherited)", @@ -1937,7 +1951,7 @@ CODE_SIGN_ENTITLEMENTS = "NFLSers-iOS.entitlements"; CODE_SIGN_IDENTITY = "iPhone Developer"; "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; - CURRENT_PROJECT_VERSION = 12; + CURRENT_PROJECT_VERSION = 15; DEVELOPMENT_TEAM = K2P3533G4D; FRAMEWORK_SEARCH_PATHS = ( "$(inherited)", diff --git a/pushNotification/Info.plist b/pushNotification/Info.plist index 628e324..a52e96f 100644 --- a/pushNotification/Info.plist +++ b/pushNotification/Info.plist @@ -17,9 +17,9 @@ CFBundlePackageType XPC! CFBundleShortVersionString - 1.2.6 + 1.2.7 CFBundleVersion - 12 + 2 NSExtension NSExtensionPointIdentifier