質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

1回答

1632閲覧

[Swift]ドラッグされたCAShapeLayerの色を変更する

sssskkkktttt

総合スコア11

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

1クリップ

投稿2018/02/14 08:24

現在Viewの中にもう一つView(worldView)があるアプリケーションを作っています。
worldViewの中にCAShapeLayerでセルを作り格子状に配置しています(画像参照)
このworldView上をドラッグされたら、ドラッグされたセルの色の変更をリアルタイムで行いたいです。
touchesMovedメソッド内で試してみましたが思うような処理を実装できません。
どなたかお力添いいただければ幸いです。

画面写真

Swift

1import UIKit 2 3class ViewController: UIViewController { 4 5 @IBOutlet weak var worldView: UIView! 6 7 var mapCell:[[CAShapeLayer]] = [[]] 8 let cellSize:Int = 10 9 var numberOfColumns:Int = 0 10 var numberOfRows:Int = 0 11 12 override func viewDidLoad() { 13 super.viewDidLoad() 14 } 15 16 override func viewDidLayoutSubviews() { 17 super.viewDidLayoutSubviews() 18 19 numberOfRows = Int(worldView.frame.width) / cellSize 20 numberOfColumns = Int(worldView.frame.height) / cellSize 21 22 for r in 0 ..< numberOfRows { 23 mapCell.append([CAShapeLayer]()) 24 for c in 0 ..< numberOfColumns { 25 let tempShapeLayer = CAShapeLayer.init() 26 //tempShapeLayer.frame = CGRect.init(x: (r*cellSize), y: (c*cellSize), width:cellSize, height:cellSize) 27 tempShapeLayer.path = UIBezierPath.init(rect: CGRect.init(x: (r*cellSize), y: (c*cellSize), width:cellSize, height:cellSize)).cgPath 28 tempShapeLayer.fillColor = UIColor.white.cgColor 29 tempShapeLayer.strokeColor = UIColor.black.cgColor 30 mapCell[r].append(tempShapeLayer) 31 worldView.layer.addSublayer(mapCell[r][c]) 32 } 33 } 34 } 35 36 override func touchesMoved(_ touches: Set<UITouch>, with event: UIEvent?) { 37 38 } 39}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

考え方としてはtouchesMovedされたときのpointが含まれるViewに色をつけることになると思います。
CAShapeLayerだと位置が取れなかったのでUIViewにしてみました。

@IBOutlet weak var worldView: UIView! var mapCell:[[UIView]] = [[]] let cellSize:Int = 10 var numberOfColumns:Int = 0 var numberOfRows:Int = 0 override func viewDidLoad() { super.viewDidLoad() } override func viewDidLayoutSubviews() { super.viewDidLayoutSubviews() numberOfRows = Int(worldView.frame.width) / cellSize numberOfColumns = Int(worldView.frame.height) / cellSize for r in 0 ..< numberOfRows { mapCell.append([UIView]()) for c in 0 ..< numberOfColumns { let view = UIView.init(frame: CGRect.init(x: (r*cellSize), y: (c*cellSize), width:cellSize, height:cellSize)) view.layer.borderColor = UIColor.black.cgColor view.layer.borderWidth = 1.0 mapCell[r].append(view) worldView.addSubview(view) } } } override func touchesMoved(_ touches: Set<UITouch>, with event: UIEvent?) { let touches = touches.first?.location(in: worldView) for cells in mapCell { for cell in cells { if cell.frame.contains(touches!) { cell.backgroundColor = UIColor.blue break } } } }

あとはview自体にtoucheEventをつけてあげるとかでも同じようなことが実装できそうですかね?
なんとなく効率の良い処理の仕方じゃない気もするので他に良い実装の仕方があれば参考にしたいです。

投稿2018/08/06 02:19

razuma

総合スコア1313

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問