テキストを白い枠線で囲んでください。私はテキストのためにCATextLayerを使用しています。 CATextLayerのborderColor/borderWidthプロパティはありません。もちろん、私はそのスーパークラス(CALayer)のプロパティを使うことができますが、テキスト自体の周りではなく、レイヤの枠の周りに境界線を描画します。誰も私がCATextLayerを使ってこれを達成する方法を知っていますか?CATextLayer font borderColor?
答えて
念のために誰かが私の解決策に興味がある:
は、基本的には直接CoreTextを使用せずにストローク(境界線)を使用してテキストを作成することが可能です。 CATextLayerのstringプロパティはNSAttributedStringsを受け入れます。したがって、その属性にストロークの色とストロークの幅を持つNSAttributedStringを与えることは簡単です。
残念ながら、私はフォントサイズをアニメーション化する必要がありました。文字列プロパティはアニメーション可能ですが、NSStringの場合のみです。そこで私はCATextLayerをサブクラス化することに決めました。多くの試みの後、私はCATextLayerの文字列とコンテンツのプロパティが互いに排他的であることを認識しました。つまり、文字列またはコンテンツのいずれかが表示されます。私は自分自身の文字列の描画を行う方法を把握できませんでした。 displayとdrawInContext:ctxメソッドは、コンテンツが更新されているときにのみ呼び出されますが、文字列を更新するために何を呼び出す必要があるかはわかりませんでした。
私は自分のCATextLayerクラスを作成し、CALayerをサブクラス化することに決めました。私はfontSizeというアニメーション可能なプロパティを作成しました。これがアニメーション化されると、drawInContext:ctxメソッドが呼び出されます。 drawInContext:ctxメソッドでは、CoreTextで新しい文字列を作成し、それに応じてfontSizeプロパティを使用してサイズを更新します。フォントサイズをアニメーションを心配することなく、ソリューションに興味がある人のために
:
@import QuartzCore;
@import CoreText;
- (void)addTextLayer
{
NSDictionary* attributes = @{ NSFontAttributeName : [UIFont boldSystemFontOfSize:40.0],
(NSString*)kCTForegroundColorAttributeName: (id)[UIColor blackColor].CGColor,
(NSString*)kCTStrokeWidthAttributeName: @(-2.0),
(NSString*)kCTStrokeColorAttributeName: (id)[UIColor whiteColor].CGColor };
CATextLayer* textLayer = [CATextLayer layer];
textLayer.string = [[NSAttributedString alloc] initWithString:@"Hello World" attributes:attributes];
// Do the rest...
}
- 1. DataGridViewCell Bordercolor
- 2. CATextLayer行数?
- 3. CATextLayerテキストフォントは
- 4. CATextLayer wrapped sizeToFit?
- 5. Interface BuilderのCATextLayer?
- 6. CATextLayerストリングプロパティのアニメーション
- 7. CATextLayerのSetFont XamarinのiOS値は
- 8. CATextLayerのフォントサイズアニメーションの速度
- 9. CATextLayerフォントをUIFontに変換します。
- 10. jQueryUIでborderColorをアニメーション化する
- 11. BorderColorプロパティでカスタムラベルを作成します。
- 12. ReactコンポーネントのborderColorを変更する
- 13. Xamarin.iOSがカスタムコントロールのbordercolorを変更する
- 14. CATextLayerの不要な埋め込み
- 15. CATextLayerでテキストを回転するには?
- 16. MonoTouchでAttributedStringを使用したCATextlayer
- 17. CATextLayerでtextBoxのサイズを調べる
- 18. CATextLayerは回転しますか?
- 19. CGContextでCATextLayerを使用する
- 20. 切り捨てを含むマルチラインCATextLayer
- 21. font-face font embedding非常に遅いfirefox
- 22. @ font-faceとcufon
- 23. CSS font-weightオプション
- 24. font-family(CSS)
- 25. Symbol font on ABCpdf
- 26. @ font-face not working
- 27. Appcelerator - font arabic IOS
- 28. フライングソーサーで@ font-face
- 29. クロスブラウザ@ font-face use
- 30. FileChooserのfont-color
何かがこれを行うための唯一の方法は、いずれかのサブクラス 'CATextLayer'にあるか、デリゲートメソッド' drawLayerを使用することを私に言っています:inContext: '実際の描画を自分で行います。 –
ご意見ありがとうございます。実装が難しいようです。ドローイングを自分でやろうと思います... – strave
[低レベルのテキストレンダリング](http://www.codeproject.com/KB/iPhone/Glyph.aspx)でこのページをチェックしてください。最初はかなり大きいですが、時間をかけて処理すれば、何が起こっているのかを知ることができます。 – pe8ter