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

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

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

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

Q&A

解決済

1回答

2630閲覧

UIButtonのカスタムクラスで、ボタンをおいているViewの座標を取得したい

soufuru

総合スコア10

Swift

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

0グッド

0クリップ

投稿2017/02/25 08:56

UIButtonのカスタムクラスで、6角形のボタンを作ろうとしています。
ストーリーボードでボタンを置き、そのクラスを下記のカスタムクラスに設定してます。親ビューの(0,0)の位置にUIButtonを置くとうまく六角形が表示されるのですが、それ以外の位置にすると表示されなくなります。

親ビューの座標が取れていないことが問題だと思うのですが、UIButtonのカスタムクラスから親ビューの座標を取る方法を知りたいです。よろしくお願いします。

swift

1import UIKit 2 3class HexagonButton: UIButton { 4 5 override init(frame: CGRect) { 6 super.init(frame: frame) 7 } 8 9 required init?(coder aDecoder: NSCoder) { 10 super.init(coder: aDecoder) 11 drawHexagon() 12 } 13 14 private func drawHexagon() { 15 let path = createHexagonPath() 16 17 let mask = CAShapeLayer() 18 mask.path = path.cgPath 19 20 self.layer.masksToBounds = true 21 self.layer.mask = mask 22 23 let borderShape = CAShapeLayer() 24 borderShape.path = path.cgPath 25 borderShape.lineWidth = 4.0 26 borderShape.strokeColor = UIColor.red.cgColor 27 borderShape.fillColor = UIColor.black.cgColor 28 self.layer.insertSublayer(borderShape, at: 0) 29 } 30 31 private func createHexagonPath() -> UIBezierPath { 32 let path = UIBezierPath() 33 34 print((superview ?? UIView()) ) 35 36 let view : UIView! = (superview ?? UIView()) 37 //6角形 38 path.move (to: CGPoint(x:self.center.x, 39 y:self.center.y + (superview?.frame.size.height)!/2)) 40 path.addLine(to: CGPoint(x:self.center.x + (superview?.frame.size.width)!/2, 41 y:self.center.y + (superview?.frame.size.height)!/4)) 42 path.addLine(to: CGPoint(x:self.center.x + (superview?.frame.size.width)!/2, 43 y:self.center.y - (superview?.frame.size.height)!/4)) 44 path.addLine(to: CGPoint(x:self.center.x, 45 y:self.center.y - (superview?.frame.size.height)!/2)) 46 path.addLine(to: CGPoint(x:self.center.x - (superview?.frame.size.width)!/2, 47 y:self.center.y - (superview?.frame.size.height)!/4)) 48 path.addLine(to: CGPoint(x:self.center.x - (superview?.frame.size.width)!/2, 49 y:self.center.y + (superview?.frame.size.height)!/4)) 50 51 path.close() 52 return path 53 } 54 55} 56

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

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

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

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

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

guest

回答1

0

ベストアンサー

座標の計算がずれているようでしたのでその部分を書きなおしてみました、試してみてください。

swift

1import UIKit 2 3class HexagonButton: UIButton { 4 5 override init(frame: CGRect) { 6 super.init(frame: frame) 7 drawHexagon() 8 } 9 10 required init?(coder aDecoder: NSCoder) { 11 super.init(coder: aDecoder) 12 drawHexagon() 13 } 14 15 private func drawHexagon() { 16 let path = createHexagonPath() 17 18 let mask = CAShapeLayer() 19 mask.path = path.cgPath 20 21 self.layer.masksToBounds = true 22 self.layer.mask = mask 23 24 let borderShape = CAShapeLayer() 25 borderShape.path = path.cgPath 26 borderShape.lineWidth = 4.0 27 borderShape.strokeColor = UIColor.red.cgColor 28 borderShape.fillColor = UIColor.black.cgColor 29 self.layer.insertSublayer(borderShape, at: 0) 30 } 31 32 private func createHexagonPath() -> UIBezierPath { 33 let path = UIBezierPath() 34 35 let x = self.center.x - self.frame.origin.x 36 let y = self.center.y - self.frame.origin.y 37 let height = self.bounds.size.height 38 let width = self.bounds.size.width 39 40 //6角形 41 path.move (to: CGPoint(x: x, 42 y: y + height / 2)) 43 path.addLine(to: CGPoint(x: x + width / 2, 44 y: y + height / 4)) 45 path.addLine(to: CGPoint(x: x + width / 2, 46 y: y - height / 4)) 47 path.addLine(to: CGPoint(x: x, 48 y: y - height / 2)) 49 path.addLine(to: CGPoint(x: x - width / 2, 50 y: y - height / 4)) 51 path.addLine(to: CGPoint(x: x - width / 2, 52 y: y + height / 4)) 53 path.close() 54 return path 55 } 56}

投稿2017/02/25 09:58

編集2017/02/25 09:59
_Kentarou

総合スコア8490

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

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

soufuru

2017/02/25 10:19

うまくいきました!素早い解答ありがとうございます!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問