How to make equal space between texts in the circular menu?

烈酒焚心 提交于 2019-12-12 01:53:26

问题


I am creating a circular slider menu, I am using coregraphics to draw the control UI, Here I am trying to draw words on the circumference of a circle. But i cant able to make the spaces equally.

Here is my code and output. Please help me to give equal spaces between each word.

In drawRect

float angleStep = 2 * M_PI / [menuArray count];
float angle = degreesToRadians(90);
textRadius = textRadius - 12;

for (NSString* text in`enter code here` titleArray)
{
    [self drawStringAtContext:ctx string:text atAngle:angle withRadius:textRadius];
    angle -= angleStep;
}

//////////

- (void) drawStringAtContext:(CGContextRef) context string:(NSString*) text atAngle:(float)angle withRadius:(float) radis

{
CGSize textSize = [text sizeWithFont:[UIFont systemFontOfSize:11.0]];

float perimeter = 2 * M_PI * radis;
float textAngle = textSize.width / perimeter * 2 * M_PI;

angle += textAngle / 2;

for (int index = 0; index < [text length]; index++)
 {
    NSRange range = {index, 1};
    NSString* letter = [text substringWithRange:range];
    char* c = (char*)[letter cStringUsingEncoding:NSASCIIStringEncoding];
    CGSize charSize = [letter sizeWithFont:[UIFont systemFontOfSize:11.0]];

    float x = radis * cos(angle);
    float y = radis * sin(angle);

    float letterAngle = (charSize.width / perimeter * -2 * M_PI);

    CGContextSaveGState(context);
    CGContextTranslateCTM(context, x, y);
    CGContextRotateCTM(context, (angle - 0.5 * M_PI));
    CGContextShowTextAtPoint(context, 0, 0, c, strlen(c));
    CGContextRestoreGState(context);

    angle += letterAngle;
}
}

Output

来源:https://stackoverflow.com/questions/29819787/how-to-make-equal-space-between-texts-in-the-circular-menu

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!