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

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

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

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

UI Design

UI Design(UIデザイン)は、ユーザインターフェースをデザインすることです。ユーザーとシステムがスムーズにコミュニケーションを取るために、OSやアプリ画面などを使いやすくデザインすることを指します。

Q&A

解決済

1回答

487閲覧

CALayerを文字で切り抜きたい

otenkiameno

総合スコア11

Swift

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

UI Design

UI Design(UIデザイン)は、ユーザインターフェースをデザインすることです。ユーザーとシステムがスムーズにコミュニケーションを取るために、OSやアプリ画面などを使いやすくデザインすることを指します。

0グッド

2クリップ

投稿2018/06/08 17:23

実現したいこと

CALayerをCAtextLayerで切り抜くにはどのようなコードを書けばいいのかわからず、困っています。
どなたかご教授いただけないでしょうか。

実現したいこと

該当のソースコード

swift

1var targetLayer:CALayer = CALayer() 2var textLayer:CATextLayer = CATextLayer() 3 4... 5 6 7textLayer.frame = CGRect(x:0, y:0, width:500, height:500) 8textLayer.fontSize = 42.0 9textLayer.string = "testing" 10 11targetLayer.frame = CGRect(x:0, y:0, width:500, height:500) 12targetLayer.backgroundColor = UIColor.black.cgColor //便宜上ベタ塗りの黒にしています 13 14 15targetLayer.mask = textLayer //???? 16

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

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

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

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

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

guest

回答1

0

ベストアンサー

CALayer.maskとCATextLayerの組み合わせでは、iOSでは無理かと思います(macOSなら可能かもしれません)。

maskプロパティで指定したレイヤーの「透明ではない部分が表示される」というような仕様(説明上簡略化しています)に従えば、「テキスト以外の部分が不透明、テキストの部分を透明」の画像を動的に生成してmaskに指定するしかないのかなと思います。

その方法で実現したサンプルが以下です。

swift

1class ViewController: UIViewController { 2 3 override func viewDidLoad() { 4 super.viewDidLoad() 5 // Do any additional setup after loading the view, typically from a nib. 6 7 view.backgroundColor = .white 8 9 // 宇宙画像のレイヤー生成 10 let targetLayer = CALayer() 11 targetLayer.contents = #imageLiteral(resourceName: "img").cgImage 12 targetLayer.backgroundColor = UIColor.black.cgColor 13 targetLayer.frame = CGRect(x: 50, y: 50, width: 300, height: 300) 14 15 // マスク画像の動的生成 16 UIGraphicsBeginImageContextWithOptions(CGSize(width: 300, height: 300), false, 0) 17 UIColor.black.setFill() 18 UIRectFill(CGRect(x: 0, y: 0, width: 300, height: 300)) 19 UIGraphicsGetCurrentContext()?.setBlendMode(.clear) // ここでclearを指定すると文字の形で画像の一部分を消すことができる 20 NSString(string: "TEST").draw(at: CGPoint(x: 60, y: 100), withAttributes: [.font: UIFont.boldSystemFont(ofSize: 70)]) 21 let maskImage = UIGraphicsGetImageFromCurrentImageContext() 22 UIGraphicsEndImageContext() 23 24 // マスクレイヤーを設定 25 let maskLayer = CALayer() 26 maskLayer.contents = maskImage?.cgImage 27 maskLayer.frame = CGRect(x: 0, y: 0, width: 300, height: 300) 28 targetLayer.mask = maskLayer 29 30 view.layer.addSublayer(targetLayer) 31 } 32}

イメージ説明

ただ、ここまでするのでしたら、maskプロパティにこだわらずに、最初から宇宙飛行士の画像を動的に加工して文字の形で部分的に消した方が手っ取り早いかなとも思います。

投稿2018/06/12 06:16

takabosoft

総合スコア8356

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

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

otenkiameno

2018/06/21 14:31

ありがとうございます...! 解決できました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問