- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试制作一个具有不同级别的菜单,而游戏只有三个开放级别。
问题在于节省铅含量。
我已经设法让关卡在打开时显示各自的编号,如果没有打开则显示挂锁。完成上一关后,将打开一个新关卡。
我希望保存它,这样当您关闭应用程序时,关卡进度不会消失。
我尝试使用 .plist 但他们不允许我使用数字作为 plist 中的变量名称,因此很难获取每个级别的信息。我告诉你。
我的.plist是一个字典矩阵,里面有其他字典,由三个组成部分(完成级别,级别,开闭)组成:
<dict>
<key>Diez5</key>
<dict>
<key>finishEnd</key>
<integer>0</integer>
<key>level</key>
<integer>10</integer>
<key>openClosed</key>
<integer>0</integer>
</dict>
<key>Once5</key>
<dict>
<key>finishEnd</key>
<integer>0</integer>
<key>level</key>
<integer>11</integer>
<key>openClosed</key>
<integer>0</integer>
</dict>
<key>Uno</key>
<dict>
<key>finishEnd</key>
<integer>0</integer>
<key>level</key>
<integer>1</integer>
<key>openClosed</key>
<integer>1</integer>
</dict>
...
...</dict>
接下来我有类(class)使用这个:
class MenuList {
var matriz4 = [["Ocho","Nueve","Diez","Once"], ["Cuatro","Cinco","Seis","Siete"], ["Matriz","Uno","Dos","Tres"]]
var matriz5 = [["Ocho5","Nueve5","Diez5","Once5"], ["Cuatro5","Cinco5","Seis5","Siete5"], ["Matriz5","Uno5","Dos5","Tres5"]]
let levelKey = "level"
let openClosedKey = "openClosed"
let finishKey = "finishEnd"
let columnNum: Int!
let rowNum: Int!
let plist = Plist(name: "MatrizMenu")
var levelID: Int!
var openCID: Int!
var finishID: Int!
init() {
self.columnNum = matriz4.count + 1
self.rowNum = matriz4.count
}
func getTile(column: Int, row: Int, matrixNum: Int) -> (SKSpriteNode,SKLabelNode) {
let textLabel = SKLabelNode(fontNamed: "HelveticaRoundedLTStd-BdCn")
textLabel.fontColor = UIColor.whiteColor()
textLabel.text = " "
switch(matrixNum){
case 4:
let dict = plist?.getMutablePlistFile()!
if let myDict = dict![matriz4[row][column]] {
openCID = myDict.valueForKey(openClosedKey) as! Int!
finishID = myDict.valueForKey(finishKey) as! Int!
if matriz4[row][column] == "Matriz" {
textLabel.text = "4x4"
return (SKSpriteNode(imageNamed: "rectangle-play"),textLabel)
} else if openCID != 0 && finishID == 0 {
levelID = myDict.valueForKey(levelKey) as! Int!
textLabel.text = "\(levelID)"
return (SKSpriteNode(imageNamed: "UnfinishTile"), textLabel)
} else if openCID != 0 && finishID != 0 {
levelID = myDict.valueForKey(levelKey) as! Int!
textLabel.text = "\(levelID)"
return (SKSpriteNode(imageNamed: "FinishTile"), textLabel)
}else {
textLabel.text = "lock"
return (SKSpriteNode(imageNamed: "rectangle-play-normal"), textLabel)
}
}
case 5:
let dict = plist?.getMutablePlistFile()!
if let myDict = dict![matriz5[row][column]] {
openCID = myDict.valueForKey(openClosedKey) as! Int!
if matriz5[row][column] == "Matriz5" {
let sprite = SKSpriteNode(color: UIColor(red: 1, green: 0.541, blue: 0.298, alpha: 1), size: CGSize(width: 50, height: 50))
textLabel.text = "5x5"
return (sprite,textLabel)
} else if openCID != 0 && finishID == 0 {
levelID = myDict.valueForKey(levelKey) as! Int!
textLabel.text = "\(levelID)"
return (SKSpriteNode(imageNamed: "UnfinishTile"), textLabel)
} else if openCID != 0 && finishID != 0 {
levelID = myDict.valueForKey(levelKey) as! Int!
textLabel.text = "\(levelID)"
return (SKSpriteNode(imageNamed: "FinishTile"), textLabel)
}else {
textLabel.text = "lock"
return (SKSpriteNode(imageNamed: "rectangle-play-normal"), textLabel)
}
}
default:
return (SKSpriteNode(), textLabel)
}
return (SKSpriteNode(), textLabel)
}
func get_level(column: Int, row: Int, matrixNum: Int) -> (Int,Bool) {
switch(matrixNum){
case 4:
let dict = plist?.getMutablePlistFile()!
if let myDict = dict!["\(matriz4[row][column])"] {
openCID = myDict.valueForKey(openClosedKey) as! Int!
levelID = myDict.valueForKey(levelKey) as! Int!
if matriz4[row][column] != "Matriz" && openCID != 0 {
return (levelID,true)
}
}
break
case 5:
let dict = plist?.getMutablePlistFile()!
if let myDict = dict!["\(matriz5[row][column])"] {
openCID = myDict.valueForKey(openClosedKey) as! Int!
levelID = myDict.valueForKey(levelKey) as! Int
if matriz5[row][column] != "Matriz5" && openCID != 0 {
return (levelID,true)
}
}
break
default:
return (0,false)
}
return (0,false)
}
func getBool(column: Int, row: Int) -> Bool {
if matriz4[row][column] == "Matriz" {
return true
} else { return false }
}
}
这是我发现可用的 plist 类 ( Help for plist ):
import CoreData
struct Plist {
//1
enum PlistError: ErrorType {
case FileNotWritten
case FileDoesNotExist
}
//2
let name:String
//3
var sourcePath:String? {
guard
let path = NSBundle.mainBundle().pathForResource(name, ofType: "plist")
else { return .None }
return path
}
//4
var destPath:String? {
guard sourcePath != .None else { return .None }
let dir = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)[0]
return (dir as NSString).stringByAppendingPathComponent("\(name).plist")
}
init?(name:String) {
//1
self.name = name
//2
let fileManager = NSFileManager.defaultManager()
//3
guard let source = sourcePath else { return nil }
guard let destination = destPath else { return nil }
guard fileManager.fileExistsAtPath(source) else { return nil }
//4
if !fileManager.fileExistsAtPath(destination) {
//5
do {
try fileManager.copyItemAtPath(source, toPath: destination)
} catch let error as NSError {
print("Unable to copy file. ERROR: \(error.localizedDescription)")
return nil
}
}
}
//1
func getValuesInPlistFile() -> NSDictionary?{
let fileManager = NSFileManager.defaultManager()
if fileManager.fileExistsAtPath(destPath!) {
guard let dict = NSDictionary(contentsOfFile: destPath!) else { return .None }
return dict
} else {
return .None
}
}
//2
func getMutablePlistFile() -> NSMutableDictionary?{
let fileManager = NSFileManager.defaultManager()
if fileManager.fileExistsAtPath(destPath!) {
guard let dict = NSMutableDictionary(contentsOfFile: destPath!) else { return .None }
return dict
} else {
return .None
}
}
//3
func addValuesToPlistFile(dictionary:NSDictionary) throws {
let fileManager = NSFileManager.defaultManager()
if fileManager.fileExistsAtPath(destPath!) {
if !dictionary.writeToFile(destPath!, atomically: false) {
print("File not written successfully")
throw PlistError.FileNotWritten
}
} else {
throw PlistError.FileDoesNotExist
}
}
那么,如何保存关卡进度呢?感谢您的帮助!
最佳答案
有几种方法可以做到这一点。我目前正在完成我的游戏,我使用 UICollectionView 有类似的菜单。为了存储数据,我在处理游戏保存的 Singleton 游戏数据类中为此创建了一个字典数组。
例如
var unlockedLevels: [[String: Bool]] = [
// Empty, so array starts at index 1 and not 0
[:],
// World 1
["1": true, "2": false, "3": false, "4": false], // Level 1-4
// World 2
...
]
然后我在我的集合 View 中使用 indexPath 来检查哪个单元格被按下并将其与数组进行比较以查看它是否已解锁并加载关卡。
let world = indexPath.section + 1 // + 1 because indexPath starts at 0
let level = indexPath.row + 1 // If collection view is horizontal need to convert this because indexPath goes up/down not left/right.
// Load level only if unlocked, otherwise exit method
guard GameData.sharedInstance.unlockedLevels[world]["\(level)"] == true else { return }
// code to load level
您不仅要确保根据关卡是否解锁来更改单元格。我在我的集合 View 的 CellForRowAtIndexPath 方法中这样做,它有 2 个单元格,1 个正常,1 个锁定。由于单元格出队和重用,我无法让它可靠地使用 1 个单元格。
let world = indexPath.section + 1
let level = indexPath.row + 1
if GameData.sharedInstance.unlockedLevels[world]["\(level)"] == true {
return cell // returns normal cell to play level
} else {
return cellLocked // returns cell with padlock.
}
完成一个级别后,将相应级别的 bool 设置为 true 并保存进度。
要保存数组,您可以使用 NSCoding、NSUserDefaults 或最佳解决方案 Keychain。
https://www.hackingwithswift.com/read/12/3/fixing-project-10-nscoding
how to don't get a nil value from NSUserDefaults in ViewDidLoad
https://github.com/jrendel/SwiftKeychainWrapper
https://www.raywenderlich.com/63235/how-to-save-your-game-data-tutorial-part-1-of-2 (Obj C 但我认为还是有用的)
不能 100% 确定这就是您要找的东西,因为我不使用 Plists。让我知道进展如何。
关于ios - 使用 sprite 工具包的级别菜单的持久性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36430861/
任何人都可以评论是否对图像使用 Sprite 的决定?我看到以下好处/权衡(其中一些可以减轻): 单个图像上的 Sprite 优点: 需要管理的图像更少 更容易实现主题图像 图像交换 (JS/CSS)
所以,我一直在 Unity 工作,但我决定是时候换成我更了解的东西了:JavaScript。我一直在考虑切换到 Phaser.js,但我有一些关于我什至在 Unity 中遇到的问题的问题,而且我在互联
所以我有一个木偶要在 Sprite Kit 中显示。木偶是由一堆不同的 body 部位组成的,当然每个部位都是一个.png。 所以我的过程是:我有一个 Marionette 对象(SKNode 子类)
我有一个 Sprite ,我将其初始化为 SKSPriteNode,它不断地从另一个 Sprite 上弹起,也以相同的方式初始化。 我无法弄清楚两者之间的冲突,并且到目前为止堆栈上没有任何帮助。 我将
标题说明了一切。我想知道 Sprite.getcontentsize、Sprite.gettexture、Sprite.getscale 之间有什么区别。以及它们是如何使用的。在这个问题之后我找不到任
我有兴趣尝试创建一些游戏,即在新的 sprite 工具包中。但是,对于我心目中的游戏,我宁愿使用方向键而不是操纵杆。因为我将从 Cocos 搬过来,所以我的旧程序不再有效(所以那个 dpad 也不会)
我正在 LibGdx 中开发 2D 射击游戏。 我不得不提一下,我是 LibGdx 的新手,我正在努力理解它是如何工作的。我有几年的Java和Android编程经验,所以我了解游戏概念。 我感兴趣的是
我正在使用 Compass 生成 CSS Sprite 。 我找到了一种方法来定义一次 Sprite 并在不同的 .scss 文件中使用它,但我不确定这是正确的解决方案。 到目前为止,我能找到的最好方
我在游戏中遇到背景音乐问题。当我从主菜单场景切换到游戏场景时,它停止,但是当游戏场景切换到gameOver场景时,它不停止。当我选择重播时,音乐也会重叠(从gameOver场景切换回游戏场景)。 要播
我是一名使用 libgdx 引擎的新程序员,想知道 Sprite 批处理的行为。特别是如何在程序生命周期中将 Sprite 添加到批处理中以进行绘制。到目前为止, Sprite 的所有示例都使用了一些
这可能是个愚蠢的问题,但如果有人能帮助我,我将不胜感激。 我有一个由 3 个垂直堆叠的不同图像组成的 Sprite ,但我试图让中间的图像(高度为 1px 和宽度为 194)重复,只是那条 1px 的
我正在尝试为我正在构建的菜单加载 spritesheet,但它不是一次显示一个图像,而是在元素的不同位置显示整个 spritesheet。 这是我使用两张图片的 CSS 代码: #mymenu ul.
我有两个 Sprite 组,ship_list 有 20 个飞船 Sprite ,all_sprites 有这 20 个 Sprite ,加上玩家 Sprite 。在主循环中,当检测到玩家与 ship
我制作了这个我可以抓取并四处移动的 Sprite 。我的问题是我希望能够“抛出” Sprite 。意思是,当我释放 Sprite 时,我希望它继续沿着我移动它的方向前进。就像扔球一样。 我该怎么办?
我目前正在开发 HTML/CSS 模板,我将实现以下社交媒体图标: http://www.premiumpixels.com/freebies/41-social-media-icons-png/ 它
在我的游戏中,我希望能够收集硬币。我有一个该硬币 Sprite 的数组列表,这样我就可以单独绘制多个硬币。这些硬币也随着背景移动(模拟汽车驾驶),我想要它,所以当硬币撞到汽车时,它会消失并被收集。感谢
我是 cocos2D 的新手,谁能提出一个简单的解决方案? 我有一个风车,风车上有 8 个条,每个条以 45 度隔开,其中风车的一半在屏幕上,一半在屏幕外。我想旋转风车,让它永远旋转。我还想在风车杆的
我使用的是主播中心分支,刚刚发现我的游戏出现的问题大部分都是这个原因。有没有一种方法可以使用 Sprite 的左下角而不是使用 (0, 0) 作为其中心来设置 Sprite ? 谢谢! 最佳答案 发现
我是 magic-importing我的 Sprite : // Creating a concatenated sprite image out of all sprites in the "/im
这个问题在这里已经有了答案: How do I detect collision in pygame? (5 个答案) 关闭去年。 想要创建一个包含 10 张图像的组。稍后屏幕上的图像不应重叠。我尝
我是一名优秀的程序员,十分优秀!