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

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

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

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

Q&A

解決済

1回答

695閲覧

CoreGraphics を使って円を描いているのですが、塗りつぶしと枠線を同時に描写するにはどうやればいいですか?

退会済みユーザー

退会済みユーザー

総合スコア0

Swift

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

0グッド

0クリップ

投稿2020/01/08 12:18

Viewの上に円を描写しているのですが、塗りつぶしか枠線の描写どちらか一方しかできません(塗りつぶし優先)、同時に描写する方法を御存知でしたら教えて下さい。

塗りつぶし
塗りつぶし

塗りつぶしをコメントアウトした場合の線のみ
塗りつぶしをコメントアウトした場合の線のみ

swift

1 2class TestView: UIView { 3 4 override func awakeFromNib() { 5 super.awakeFromNib() 6 7 layer.cornerRadius = 5.0 8 clipsToBounds = true 9 } 10 11 override func draw(_ rect: CGRect) { 12 super.draw(rect) 13 14 let ctx: CGContext? = UIGraphicsGetCurrentContext() 15 16 let circleSize: CGFloat = self.bounds.size.width / 2 17 let center = CGPoint(x: self.frame.width / 2, y: self.frame.height / 2) 18 19 let lineWidth: CGFloat = 4.0 20 let lineColor: UIColor = UIColor.white 21 let fillColor: UIColor = UIColor.green 22 23 ctx?.setLineWidth(lineWidth) 24 ctx?.setStrokeColor(lineColor.cgColor) 25 ctx?.setFillColor(fillColor.cgColor) 26 27 ctx?.addArc(center: center, radius: circleSize * 0.5, startAngle: 0.0, endAngle: CGFloat(.pi * 2.0), clockwise: false) 28 29 ctx?.setLineWidth(lineWidth) 30 31 ctx?.fillPath() 32 ctx?.strokePath() 33 } 34}

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

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

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

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

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

guest

回答1

0

ベストアンサー

たしか

ctx?.drawPath(using: .fillStroke)

だったと思います。

投稿2020/01/09 01:59

takabosoft

総合スコア8356

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

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

退会済みユーザー

退会済みユーザー

2020/01/09 04:27

回答ありがとうございます。塗りつぶし、パス同時に描写できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問