5
新しいios 7の電話アプリにお気に入りセクションがあります。そのセクションでは、連絡先の名前は、円の内側の連絡先の最初の部分に表示されます。iOS 7の文字で塗りつぶされた円を描く
これはどのように描かれますか? drawrectで、またはこれのために既に作成されたオブジェクトがありますか?
新しいios 7の電話アプリにお気に入りセクションがあります。そのセクションでは、連絡先の名前は、円の内側の連絡先の最初の部分に表示されます。iOS 7の文字で塗りつぶされた円を描く
これはどのように描かれますか? drawrectで、またはこれのために既に作成されたオブジェクトがありますか?
以下は、あなたが望むことをするUIView
サブクラスです。円の中の1つ以上の文字のサイズと位置を正しく設定します。ここでは、様々なサイズ(32、64、128、256)で1〜3つの文字でどのように見えるかです:Interface Builderでユーザー定義のランタイム属性の可用性と
、あなたものビューを設定することができますIB内。ランタイムアトリビュートとしてtext
プロパティを設定し、円に使用する色にbackgroundColor
を設定してください。
@interface MELetterCircleView : UIView
/**
* The text to display in the view. This should be limited to
* just a few characters.
*/
@property (nonatomic, strong) NSString *text;
@end
@interface MELetterCircleView()
@property (nonatomic, strong) UIColor *circleColor;
@end
@implementation MELetterCircleView
- (instancetype)initWithFrame:(CGRect)frame text:(NSString *)text
{
NSParameterAssert(text);
self = [super initWithFrame:frame];
if (self)
{
self.text = text;
}
return self;
}
// Override to set the circle's background color.
// The view's background will always be clear.
-(void)setBackgroundColor:(UIColor *)backgroundColor
{
self.circleColor = backgroundColor;
[super setBackgroundColor:[UIColor clearColor]];
}
- (void)drawRect:(CGRect)rect
{
CGContextRef context = UIGraphicsGetCurrentContext();
[self.circleColor setFill];
CGContextAddArc(context, CGRectGetMidX(rect), CGRectGetMidY(rect),
CGRectGetWidth(rect)/2, 0, 2*M_PI, YES);
CGContextFillPath(context);
[self drawSubtractedText:self.text inRect:rect inContext:context];
}
- (void)drawSubtractedText:(NSString *)text inRect:(CGRect)rect
inContext:(CGContextRef)context
{
CGContextSaveGState(context);
// Magic blend mode
CGContextSetBlendMode(context, kCGBlendModeDestinationOut);
CGFloat pointSize =
[self optimumFontSizeForFont:[UIFont boldSystemFontOfSize:100.f]
inRect:rect
withText:text];
UIFont *font = [UIFont boldSystemFontOfSize:pointSize];
// Move drawing start point for centering label.
CGContextTranslateCTM(context, 0,
(CGRectGetMidY(rect) - (font.lineHeight/2)));
CGRect frame = CGRectMake(0, 0, CGRectGetWidth(rect), font.lineHeight)];
UILabel *label = [[UILabel alloc] initWithFrame:frame];
label.font = font;
label.text = text;
label.textAlignment = NSTextAlignmentCenter;
label.backgroundColor = [UIColor clearColor];
[label.layer drawInContext:context];
// Restore the state of other drawing operations
CGContextRestoreGState(context);
}
-(CGFloat)optimumFontSizeForFont:(UIFont *)font inRect:(CGRect)rect
withText:(NSString *)text
{
// For current font point size, calculate points per pixel
CGFloat pointsPerPixel = font.lineHeight/font.pointSize;
// Scale up point size for the height of the label.
// This represents the optimum size of a single letter.
CGFloat desiredPointSize = rect.size.height * pointsPerPixel;
if ([text length] == 1)
{
// In the case of a single letter, we need to scale back a bit
// to take into account the circle curve.
// We could calculate the inner square of the circle,
// but this is a good approximation.
desiredPointSize = .80*desiredPointSize;
}
else
{
// More than a single letter. Let's make room for more.
desiredPointSize = desiredPointSize/[text length];
}
return desiredPointSize;
}
@end
http://stackoverflow.com/questions/18716751/drawing-a-path-with-subtracted-text-に私の答えを見てみましょう:ここ
コードですコアグラフィックスの使用/ 18830509#18830509。それが役に立ったら教えてください。 –私はそれを理解しますが、あなたの答えも参照します。私はコアグラフィックスとUILabelを使用しました。 – cdub
@chris下記の私の答えをご覧ください。それが役に立ったら、それを受け入れたものとしてマークしてください。 – memmons