{"id":426,"date":"2024-09-22T22:53:54","date_gmt":"2024-09-22T22:53:54","guid":{"rendered":"https:\/\/wp.shimayugu.jp\/?p=426"},"modified":"2024-11-09T07:49:39","modified_gmt":"2024-11-08T22:49:39","slug":"%e6%96%b0swift%e3%81%a7%e8%a1%8c%e3%81%93%e3%81%86%e7%ac%ac%ef%bc%94%ef%bc%95%e5%9b%9e%e3%80%8c%e3%83%90%e3%83%90%e6%8a%9c%e3%81%8d%ef%bc%91%ef%bc%94%e3%80%8d%e3%80%80%e7%94%b0%e9%83%a8","status":"publish","type":"post","link":"https:\/\/wp.shimayugu.jp\/?p=426","title":{"rendered":"\u65b0Swift\u3067\u884c\u3053\u3046\u2026\u7b2c\uff14\uff15\u56de\u300c\u30d0\u30d0\u629c\u304d\uff11\uff14\u300d\u3000\u7530\u90e8\u4e95\u4fdd"},"content":{"rendered":"\n<p><a href=\"https:\/\/shimayugu.sakura.ne.jp\/?p=2298\">\u76ee\u6b21<\/a>\u3000<a href=\"https:\/\/wp.shimayugu.jp\/?p=878\">\u89e3\u8aac\u7de8<\/a><\/p>\n\n\n\n<p>\u3000\u4eca\u307e\u3067\u4f5c\u3063\u3066\u304d\u305f\u3082\u306e\u3092\u7d44\u307f\u5408\u308f\u305b\u3066\u3001\u30b2\u30fc\u30e0\u304c\u51fa\u6765\u308b\u3088\u3046\u306b\u3057\u307e\u3059\u3002\u3068\u308a\u3042\u3048\u305a\u3001\u304d\u3061\u3093\u3068\u52d5\u4f5c\u3057\u3066\u3044\u308b\u304b\u78ba\u304b\u3081\u308b\u70ba\u306b\u30ab\u30fc\u30c9\u306f\u8868\u306e\u307e\u307e\u306b\u3057\u307e\u3059\u3002\u307e\u305f\u3001\u4e00\u3064\u305a\u3064\u51e6\u7406\u3092\u6b62\u3081\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u3000\u3068\u308a\u3042\u3048\u305a\u30e6\u30fc\u30b6\u30fc\u306f\uff13\u756a\u76ee\u3092\u9078\u3076\u3068\u3057\u3066\u3001\uff11\u756a\u76ee\u3060\u3063\u305f\u6642\uff08\u6700\u521d\u306b\u30ab\u30fc\u30c9\u3092\u4e26\u3073\u66ff\u3048\u308b\u51e6\u7406\u3092\u884c\u3046\u3002\u4e26\u3073\u66ff\u3048\u306e\u25fc\ufe0e\u3092\u51fa\u3059\uff09\u3001\uff12\u756a\u76ee\u3060\u3063\u305f\u6642\uff08\uff11\u756a\u76ee\u304b\u3089\u5f15\u304f\u30ab\u30fc\u30c9\u3092\u9078\u3076\u70ba\u306b\u9078\u629e\u306e\u25fc\ufe0e\u3092\u51fa\u3059\uff09\u306e\u4f8b\u5916\u7684\u306a\u51e6\u7406\u3092\u66f8\u304b\u306a\u304f\u3066\u826f\u304f\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u3000\u4eca\u56de\u306e\u96e3\u6613\u5ea6\u306f\u7d50\u69cb\u9ad8\u3044\u3067\u3059\u3002<\/p>\n\n\n\n<p>\u3000\u4ee5\u4e0b\u3001\u5168\u4f53\u306e\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u3067\u3059\u3002\u30dc\u30bf\u30f3\u3092\u62bc\u3057\u305f\u6642\u306e\u51e6\u7406\u306b\u5272\u308a\u5f53\u3066\u3089\u308c\u3066\u3044\u305f\u3082\u306e\u3092\u3001\u62bc\u3057\u305f\u51e6\u7406\u3067\u306f\u306a\u304f\u72ec\u7acb\u3057\u3066\u52d5\u304f\u3088\u3046\u306b\u3057\u3066\u3044\u308b\u95a2\u6570\u304c\u7d50\u69cb\u3042\u308a\u307e\u3059\u3002shuffle\u95a2\u6570\u304b\u3089get\u95a2\u6570\u304c\u5206\u96e2\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-swift\" data-lang=\"Swift\" data-line=\"107,151,212,213,218,219,238,240-260,271,272,282,283,305,334,335,343,344,346-400\" data-show-lang=\"1\"><code>\/\/\n\/\/  ViewController.swift\n\/\/  baba\n\/\/\n\/\/  Created by \u4fdd Tabei on 2024\/09\/15.\n\/\/\n\nimport UIKit\n\nclass ViewController: UIViewController {\n    \n    override func viewDidLoad() {\n        super.viewDidLoad()\n        \/\/ Do any additional setup after loading the view.\n        put53()\n    }\n    \n    var eachCard: [[UILabel]] = [[],[],[],[]]\n    var eachButton: [UIButton] = []\n    var cardObj:Card = Card(cdCnt: Card.EnumCard.joker)\n    func put53() {\n        for i in 0 ..&lt; 4 {\n            for j in 0 ..&lt; 14 {\n                let lbl = UILabel(frame: CGRectMake(0, 0, 50, 21))\n                lbl.center = CGPointMake(50 + 40 * CGFloat(j % 7), 150 + 120 * CGFloat(i) +\n                                         50 * CGFloat(j \/ 7))\n                lbl.textAlignment = NSTextAlignment.center\n                if i != 0 && j == 13 {\n                    lbl.text = &quot; &quot;\n                } else {\n                    lbl.text = &quot;\u2b1b\ufe0f&quot;\n                }\n                eachCard[i] += [lbl]\n                self.view.addSubview(lbl)\n            }\n            let btn = UIButton(frame: CGRectMake(0, 0, 50, 21)) as UIButton\n            btn.center = CGPointMake(20, 150 + 120 * CGFloat(i) + 25)\n            btn.setTitle(&quot;\u26aa\ufe0f&quot;, for: .normal)\n            btn.setTitleColor(UIColor.black, for: .normal)\n            btn.addTarget(self, action: #selector(btnTapped), for: .touchUpInside)\n            btn.tag = i\n            eachButton += [btn]\n            self.view.addSubview(btn)\n        }\n        share()\n        show()\n    }\n    \n    var btnEnable = true\n    \n    @objc func btnTapped(sender: UIButton) {\n        if btnEnable == false {\n            return\n        }\n        for i in 0 ..&lt; 4 {\n            if eachButton[i] == sender {\n                if sender.currentTitle == &quot;\u26aa\ufe0f&quot; {\n                    sender.setTitle(&quot;\u26ab\ufe0f&quot;, for: .normal)\n                } else {\n                    sender.setTitle(&quot;\u26aa\ufe0f&quot;, for: .normal)\n                }\n            } else {\n                eachButton[i].setTitle(&quot;\u26aa\ufe0f&quot;, for: .normal)\n            }\n        }\n    }\n    \n    func share() {\n        btnEnable = true\n        cardObj.reset()\n        for i in 0 ..&lt; 4 {\n            for j in 0 ..&lt; 14 {\n                if i != 0 && j == 13 {\n                    eachCard[i][j].tag = -1\n                } else {\n                    var ii: Int\n                    ii = cardObj.put()\n                    eachCard[i][j].text = cardObj.disp(card: ii)\n                    eachCard[i][j].tag = ii\n                }\n            }\n        }\n    }\n    \n    func show() {\n        for i in 0 ..&lt; 4 {\n            for j in 0 ..&lt; 14 {\n                if eachCard[i][j].tag &gt;= 0 {\n                    eachCard[i][j].text = cardObj.disp(card: eachCard[i][j].tag)\n                } else {\n                    eachCard[i][j].text = &quot;\u3000&quot;\n                }\n            }\n        }\n    }\n    \n    @IBAction func btnGoTouch(_ sender: Any) {\n        share()\n        show()\n    }\n    \n    @IBAction func btnPairTouch(_ sender: Any) {\n        var selected = false\n        for i in 0 ..&lt; 4 {\n            if eachButton[i].currentTitle == &quot;\u26ab\ufe0f&quot; {\n                selected = true\n                mine = i\n                break\n            }\n        }\n        if !selected {\n            let alert = UIAlertController()\n            alert.title = &quot;\u9078\u629e&quot;\n            alert.message = &quot;\uff14\u7d44\u306e\u3046\u3061\u306e\u3069\u308c\u304b\u3092\u9078\u629e\u3057\u3066\u4e0b\u3055\u3044\u3002&quot;\n            alert.addAction(UIAlertAction(title: &quot;OK&quot;, style: .default))\n            present(alert, animated: true, completion: nil)\n            return\n        }\n        btnEnable = false\n        for i in 0 ..&lt; 4 {\n            for j in 0 ..&lt; 13 {\n                if (eachCard[i][j].tag == 52) || (eachCard[i][j].tag == -1) {\n                    continue\n                }\n                for k in j + 1 ..&lt; 14 {\n                    if (eachCard[i][k].tag == 52) || (eachCard[i][k].tag == -1) {\n                        continue\n                    }\n                    if (eachCard[i][j].tag % 13) == (eachCard[i][k].tag % 13) {\n                        eachCard[i][j].tag = -1\n                        eachCard[i][k].tag = -1\n                        break\n                    }\n                }\n            }\n            var find = false\n            var k = 0\n            for j in 0 ..&lt; 14 {\n                if eachCard[i][j].tag == -1 {\n                    find = true\n                } else {\n                    if find {\n                        eachCard[i][k].tag = eachCard[i][j].tag\n                        eachCard[i][j].tag = -1\n                    }\n                    k += 1\n                }\n            }\n        }\n        show()\n        step = 0\n    }\n    \n    func take(i: Int, randm: Bool) {\n        var kl = 0\n        for j in 0 ..&lt; 14 {\n            if eachCard[i][j].tag == -1 {\n                kl = j\n                break\n            }\n        }\n        var k = 0\n        if randm {\n            k = Int.random(in: 0 ..&lt; kl)\n        } else {\n            for j in 0 ..&lt; kl {\n                if eachCardButton[j].tag == 1 {\n                    k = j\n                    break\n                }\n            }\n        }\n        \n        var ii = 0\n        if i &lt; 3 {\n            ii = i + 1\n        } else {\n            ii = 0\n        }\n        var stop = false\n        if eachCard[i][k].tag != 52 {\n            for jj in 0 ..&lt; 14 {\n                if stop {\n                    eachCard[ii][jj - 1].tag = eachCard[ii][jj].tag\n                }\n                if eachCard[ii][jj].tag == -1 {\n                    break\n                }\n                if eachCard[ii][jj].tag == 52 {\n                    continue\n                }\n                if (eachCard[ii][jj].tag % 13) == (eachCard[i][k].tag % 13) {\n                    stop = true\n                }\n            }\n        }\n        if stop == false {\n            for jj in 0 ..&lt; 14 {\n                if eachCard[ii][jj].tag == -1 {\n                    eachCard[ii][jj].tag = eachCard[i][k].tag\n                    break\n                }\n            }\n        }\n        for j in k + 1 ..&lt; 14 {\n            eachCard[i][j - 1].tag = eachCard[i][j].tag\n        }\n        eachCard[i][13].tag = -1\n        show()\n    }\n    \n    func hiku() {\n        take(i: step, randm: true)\n    }\n    \n    var eachCardButton: [UIButton] = []\n    \n    func shuffle() {\n        let i = step\n        var kl = 0\n        var cardList: [Int] = []\n        for j in 0 ..&lt; 14 {\n            if eachCard[i][j].tag == -1 {\n                kl = j\n                break\n            }\n            cardList += [eachCard[i][j].tag]\n        }\n        \n        for j in 0 ..&lt; kl {\n            let jj = Int.random(in: 0 ..&lt; kl - j)\n            eachCard[i][j].tag = cardList[jj]\n            for k in jj ..&lt; kl - j - 1 {\n                cardList[k] = cardList[k + 1]\n            }\n        }\n        show()\n    }\n     \n    func get() {\n        var i = step\n        var kl = 0\n        for j in 0 ..&lt; 14 {\n            if eachCard[i][j].tag == -1 {\n                kl = j\n                break\n            }\n        }\n\n        for j in 0 ..&lt; kl {\n            let btn = UIButton(frame: CGRectMake(0, 0, 50, 21))\n            btn.center = CGPointMake(50 + 40 * CGFloat(j % 7), 150 + 120 * CGFloat(i) + 50 * CGFloat(j \/ 7))\n            btn.setTitle(&quot;\u25fc\ufe0e&quot;, for: .normal)\n            btn.setTitleColor(UIColor.blue, for: .normal)\n            btn.addTarget(self, action: #selector(cardBtnTapped), for: .touchUpInside)\n            btn.tag = 0\n            eachCardButton += [btn]\n            self.view.addSubview(btn)\n        }\n    }\n    \n    @objc func cardBtnTapped(sender: UIButton) {\n        for cardBtn in eachCardButton {\n            cardBtn.setTitleColor(UIColor.blue, for: .normal)\n            cardBtn.tag = 0\n        }\n        sender.setTitleColor(UIColor.red, for: .normal)\n        sender.tag = 1\n    }\n    \n    func btnHikuTouch() {\n        take(i: step, randm: false)\n        \n        for cardBtn in eachCardButton {\n            cardBtn.removeFromSuperview()\n        }\n        eachCardButton.removeAll()\n    }\n    \n    var eachChangeButton: [UIButton] = []\n    \n    func btnChangeTouch() {\n        var i = mine\n        var kl = 0\n        for j in 0 ..&lt; 14 {\n            if eachCard[i][j].tag == -1 {\n                kl = j\n                break\n            }\n        }\n        \n        for j in 0 ..&lt; kl {\n            let btn = UIButton(frame: CGRectMake(0, 0, 50, 21))\n            btn.center = CGPointMake(50 + 40 * CGFloat(j % 7), 150 + 120 * CGFloat(i) + 50 * CGFloat(j \/ 7))\n            btn.setTitle(&quot;\u25fc\ufe0e&quot;, for: .normal)\n            btn.setTitleColor(UIColor.blue, for: .normal)\n            btn.addTarget(self, action: #selector(cardChangeTapped), for: .touchUpInside)\n            btn.tag = 0\n            eachChangeButton += [btn]\n            self.view.addSubview(btn)\n        }\n    }\n    \n    @objc func cardChangeTapped(sender: UIButton) {\n        var i = mine\n        var j = 0\n        var k = 0\n        for cardBtn in eachChangeButton {\n            if cardBtn == sender {\n                break;\n            }\n            k += 1\n        }\n        var dis = false\n        for cardBtn in eachChangeButton {\n            if cardBtn.tag == 1 {\n                var change = eachCard[i][j].tag\n                eachCard[i][j].tag = eachCard[i][k].tag\n                eachCard[i][k].tag = change\n                cardBtn.setTitleColor(UIColor.blue, for: .normal)\n                cardBtn.tag = 0\n                dis = true\n                show()\n                break\n            }\n            j += 1\n        }\n        if dis == false {\n            sender.setTitleColor(UIColor.red, for: .normal)\n            sender.tag = 1\n        }\n    }\n    \n    func changeFinishTouch() {\n        take(i: step, randm: true)\n        \n        for changeBtn in eachChangeButton {\n            changeBtn.removeFromSuperview()\n        }\n        eachChangeButton.removeAll()\n    }\n    \n    var step = 0\n    var mine = 0\n    \n    @IBAction func btnExecTouch(sender: AnyObject) {\n        var reMine = mine - 1\n        if reMine == -1 {\n            reMine = 3\n        }\n        if step == reMine {\n            var i = step\n            var kl = 0\n            for j in 0 ..&lt; 14 {\n                if eachCard[i][j].tag == -1 {\n                    kl = j\n                    break\n                }\n            }\n            var k = true\n            for j in 0 ..&lt; kl {\n                if Int(eachCardButton[j].tag) == 1 {\n                    k = false\n                    break\n                }\n            }\n            if k {\n                var alert = UIAlertController()\n                alert.title = &quot;\u9078\u629e&quot;\n                alert.message = &quot;\u5f15\u304f\u30ab\u30fc\u30c9\u3092\u9078\u629e\u3057\u3066\u4e0b\u3055\u3044\u3002&quot;\n                alert.addAction(UIAlertAction(title: &quot;OK&quot;, style: .default))\n                present(alert, animated: true, completion: nil)\n                return\n            }\n            btnHikuTouch()\n            step += 1\n            if step &gt; 3 {\n                step = 0\n            }\n            btnChangeTouch()\n            \n        } else if step == mine {\n            changeFinishTouch()\n            step += 1\n            if step &gt; 3 {\n                step = 0\n            }\n            shuffle()\n        } else {\n            hiku()\n            step += 1\n            if step &gt; 3 {\n                step = 0\n            }\n            shuffle()\n        }\n        if step == reMine {\n            get()\n        }\n    }\n}<\/code><\/pre><\/div>\n\n\n\n<p>\u3000\u3055\u3066\u6b21\u56de\u306f\u3001\u4f8b\u5916\u3068\u3057\u3066\u8003\u616e\u3057\u306a\u304b\u3063\u305f\u90e8\u5206\u306e\u4f5c\u308a\u8fbc\u307f\u306b\u5165\u308a\u307e\u3059\u3002\uff11\u756a\u76ee\u3068\uff12\u756a\u76ee\u304c\u9078\u3070\u308c\u305f\u6642\u306e\u51e6\u7406\u3067\u3059\u3002\u307e\u305f\u3001\u914d\u308a\u76f4\u3057\u30dc\u30bf\u30f3\u304c\u62bc\u3055\u308c\u305f\u6642\u306b\u9752\u30ac\u30a4\u30c9\u304c\u51fa\u3066\u3044\u305f\u3089\u6d88\u3059\u51e6\u7406\u3082\u52a0\u3048\u307e\u3059\u3002<\/p>\n\n\n\n<p><a href=\"https:\/\/shimayugu.sakura.ne.jp\/?p=2298\">\u76ee\u6b21<\/a>\u3000<a href=\"https:\/\/wp.shimayugu.jp\/?p=878\">\u89e3\u8aac\u7de8<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u76ee\u6b21\u3000\u89e3\u8aac\u7de8 \u3000\u4eca\u307e\u3067\u4f5c\u3063\u3066\u304d\u305f\u3082\u306e\u3092\u7d44\u307f\u5408\u308f\u305b\u3066\u3001\u30b2\u30fc\u30e0\u304c\u51fa\u6765\u308b\u3088\u3046\u306b\u3057\u307e\u3059\u3002\u3068\u308a\u3042\u3048\u305a\u3001\u304d\u3061\u3093\u3068\u52d5\u4f5c\u3057\u3066\u3044\u308b\u304b\u78ba\u304b\u3081\u308b\u70ba\u306b\u30ab\u30fc\u30c9\u306f\u8868\u306e\u307e\u307e\u306b\u3057\u307e\u3059\u3002\u307e\u305f\u3001\u4e00\u3064\u305a\u3064\u51e6\u7406\u3092\u6b62\u3081\u307e\u3059\u3002 \u3000\u3068\u308a\u3042\u3048\u305a\u30e6\u30fc\u30b6\u30fc\u306f\uff13\u756a\u76ee\u3092\u9078\u3076\u3068 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[4],"tags":[],"class_list":["post-426","post","type-post","status-publish","format-standard","hentry","category-swift"],"_links":{"self":[{"href":"https:\/\/wp.shimayugu.jp\/index.php?rest_route=\/wp\/v2\/posts\/426","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/wp.shimayugu.jp\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/wp.shimayugu.jp\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/wp.shimayugu.jp\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/wp.shimayugu.jp\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=426"}],"version-history":[{"count":6,"href":"https:\/\/wp.shimayugu.jp\/index.php?rest_route=\/wp\/v2\/posts\/426\/revisions"}],"predecessor-version":[{"id":947,"href":"https:\/\/wp.shimayugu.jp\/index.php?rest_route=\/wp\/v2\/posts\/426\/revisions\/947"}],"wp:attachment":[{"href":"https:\/\/wp.shimayugu.jp\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=426"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/wp.shimayugu.jp\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=426"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/wp.shimayugu.jp\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=426"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}