線を描くのが好きなのですが、ccDrawLine serrate 内の cocos2d で線のぼかしを描く方法を教えてください。
ccDrawLine( ccp(StartP.x, StartP.y), ccp(EndP.x, EndP.y) );
線を描くのが好きなのですが、ccDrawLine serrate 内の cocos2d で線のぼかしを描く方法を教えてください。
ccDrawLine( ccp(StartP.x, StartP.y), ccp(EndP.x, EndP.y) );
ccDrawLine は使用しませんでしたが、Sprite を使用してラインを作成し、それをアニメーション化しました (以下のコードを参照)。このようにして、作成したカスタム ライン イメージを使用することができました (気にしないでください。それが私が行った方法です)。
プリミティブに固執したい場合は、ライン プリミティブの不透明度を設定する必要があると思います (方法を説明するこの投稿を参照)。次に、不透明度レベルを設定する一連のアクションを作成できます (たとえば、不透明度 100% で開始し、次に75% にしてから、画像で行ったように 100% に戻しますが、上記のリンクの方法を使用してぼかし効果を得ます..
画像を使用したコード:
CCSprite * string = [self getChildByTag:tag];
[string setOpacity:100]; 
NSMutableArray* frames = [[NSMutableArray alloc]initWithCapacity:3];
NSString*lineFrame = [NSString stringWithString:@"line0.png"];            
CCSpriteFrame* frame = [[CCSpriteFrameCache sharedSpriteFrameCache]spriteFrameByName:lineFrame];
[frames addObject:frame];
lineFrame = [NSString stringWithString:@"line1.png"];
frame = [[CCSpriteFrameCache sharedSpriteFrameCache]spriteFrameByName:lineFrame];
[frames addObject:frame];
lineFrame = [NSString stringWithString:@"line0.png"];
frame = [[CCSpriteFrameCache sharedSpriteFrameCache]spriteFrameByName:lineFrame];
[frames addObject:frame];
CCAnimation* anim = [CCAnimation animationWithFrames:frames delay:0.1f];
CCAnimate* animate = [CCAnimate actionWithAnimation:anim];
//CCRepeatForever* repeat = [CCRepeatForever actionWithAction:animate];
[string runAction:animate];
[string setOpacity:75];
これが役立つことを願っています..
#import "cocos2d.h"
@interface CClineSprite : CCLayer
{
    CCRenderTexture * renderTarget;
    NSMutableArray  * pathArray;
    CCSprite        * pathBrush;
    CGPoint           prePosition;
}
-(void)setLinePosition:(CGPoint)position;
-(void)setLineOpacity:(GLubyte) anOpacity;
-(void)setLineScale:(float) scale;
-(void)setLineColor:(ccColor3B) color;
@end
#import "CClineSprite.h"
@implementation CClineSprite
- (id) init
{
    self = [super init];
    if (self)
    {
        CGSize s = [[CCDirector sharedDirector] winSize];
        renderTarget = [CCRenderTexture renderTextureWithWidth:s.width height:s.height];
        [renderTarget setPosition:ccp(s.width/2, s.height/2)];
        [self addChild:renderTarget z:1];
        pathBrush = [CCSprite spriteWithFile:@"dots.png"];
        pathBrush.color = ccWHITE;
        [pathBrush setOpacity:100];
        [pathBrush setScale:0.5];
        pathArray = [[NSMutableArray alloc]init];
    }
    return self;
}
-(void)setLineOpacity:(GLubyte) anOpacity
{
    [pathBrush setOpacity:anOpacity];
}
-(void)setLineScale:(float) scale
{
    [pathBrush setScale:scale];
}
-(void)setLineColor:(ccColor3B) color
{
    [pathBrush setColor:color];
}
-(void)setLinePosition:(CGPoint)position
{
    [pathArray addObject:[NSValue valueWithCGPoint:position]];
    [self renderPath];
}
- (void) renderPath
{
    [renderTarget clear:0 g:0 b:0 a:0];
    [renderTarget begin];
    for (int i = 0; i < pathArray.count-1;i++)
    {
        CGPoint pt1;
        CGPoint pt2;
        [[pathArray objectAtIndex:i] getValue: &pt1];
        [[pathArray objectAtIndex:i + 1] getValue: &pt2];
        float distance = ccpDistance(pt1, pt2);
        if (distance > 1)
        {
            int d = (int)distance;
            for (int i = 0; i < d; i += 10)
            {
                float difx = pt2.x - pt1.x;
                float dify = pt2.y - pt1.y;
                float delta = (float)i / distance;
                [pathBrush setPosition:ccp(pt1.x + (difx * delta), pt1.y + (dify * delta))];
                [pathBrush visit];
            }
        }
    }
    [renderTarget end];
}
@end
利用方法:
CClineSprite* streak = [CClineSprite node];
[self addChild:streak z:999];
[streak setLinePosition:associatedTurtleObject.position];
[streak setLineScale:0.4];
行を動的に更新または延長するには、単に使用します
[streak setLinePosition:ccp(x,y)];
これにより、より柔軟に使用できるようになることを願っています