如何不用圖片繪製圖形精靈

我們有時常常需要一些圓形或者方形的背景,來修飾其他精靈,而專門畫張圖片又有點麻煩,這時就需要自己用程序來繪製了。

最常見的兩種:

方形精靈

-(CCSprite*) createSpriteRectangleWithSize:(CGSize)size
{
    CCSprite *sprite = [CCSprite node];
    GLubyte *buffer = malloc(sizeof(GLubyte)*4);
    for (int i=0;i<4;i++) {buffer[i]=255;}
    CCTexture2D *tex = [[CCTexture2D alloc] initWithData:buffer pixelFormat:kCCTexture2DPixelFormat_RGB5A1 pixelsWide:1 pixelsHigh:1 contentSize:size];
    [sprite setTexture:tex];
    [sprite setTextureRect:CGRectMake(0, 0, size.width, size.height)];
    free(buffer);
    return sprite;
}

圓形精靈

-(CCSprite*) createSpriteCircleWithRadius:(float)radius
{
    
    CGSize circleSize = CGSizeMake(radius*2*CC_CONTENT_SCALE_FACTOR(), radius*2*CC_CONTENT_SCALE_FACTOR());
    CGContextRef context = CGBitmapContextCreate(NULL, circleSize.width, circleSize.height, 8, 0,CGColorSpaceCreateDeviceRGB(), kCGImageAlphaPremultipliedLast);
    float lengths[] = {10,10};
    CGContextSetLineDash(context, 0, lengths, 2);
    CGContextSetRGBStrokeColor(context, 0.65, 0.65, 0.65, 1.0);
    CGContextSetLineWidth(context, 2);
    
    CGContextAddArc(context, circleSize.width/2, circleSize.height/2 , circleSize.width/2, 0,2*M_PI,1);
    CGContextDrawPath(context,kCGPathStroke);
    
    CGImageRef shadowedCGImage = CGBitmapContextCreateImage(context);
    CGContextRelease(context);
    
    UIImage * shadowedImage = [UIImage imageWithCGImage:shadowedCGImage];
    CGImageRelease(shadowedCGImage);
    
    [[CCTextureCache sharedTextureCache] addCGImage:[shadowedImage CGImage] forKey:@"circleKey"];
    return [CCSprite spriteWithTexture:[[CCTextureCache sharedTextureCache] textureForKey:@"circleKey"]];
}


以上兩種,分別用不同的方法來進行繪製,同理,修改內容,也可以繪製各種自己想要的圖形,設置自己想要的顏色和透明度



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章