0

UIview に他のいくつかのサブビューを描画しています。次に、この UIView の DrawRect メソッドで、ベジェ曲線を描いています。

残念ながら、ベジエ曲線は表示されません。ベジエ曲線がビューの背景の後ろにあることを確認しました (背景ビューを削除すると表示されます)。

カスタム描画を Quartz やその他の UISubview と組み合わせるにはどうすればよいですか?

ビューの UIView は xib に保持されます。xib をロードしてから、ビューの Drawrect メソッドで曲線を描画します。

これは、私が話している UIView の実装コードです。

#import "DandiGameView.h"
#import "SeedView.h"
#import "Defines.h"

@implementation DandiGameView

@synthesize flowerHeadPosition, blowVolume, seedArray, trunkTop;

- (void)awakeFromNib {
 [super awakeFromNib];
 //self.clearsContextBeforeDrawing = YES;
 [self animateTrunk:1 andWindVolume:1.0];
 self.seedArray = [NSMutableArray array];
 UIImageView *tmpImageView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"TRUNKTOP.PNG"]];
 [tmpImageView setCenter:flowerHeadPosition];
 self.trunkTop = tmpImageView;
 [tmpImageView release];
 //[tmpImageView sett]
 [self addSubview:self.trunkTop];
 [tmpImageView release];
}

- (id)initWithCoder:(NSCoder *)decoder
{
    if (self = [super initWithCoder:decoder])
    {
  // Initialization code
  float pointX =  FLOWER_POSITION_HOR - FLOWER_TRUNK_WIDTH / 2.0;
  float topPointY =  self.bounds.size.height - FLOWER_POSITION_VER;
  flowerHeadPosition = CGPointMake(pointX, topPointY);
  s = CGPointMake(pointX, self.bounds.size.height);
  e = flowerHeadPosition;
  cp1 = CGPointMake(pointX + 10.0, self.bounds.size.height - FLOWER_LOWER_CONTROLPOINT);
  cp2 = CGPointMake(pointX - 10.0, self.bounds.size.height - FLOWER_UPPER_CONTROLPOINT);
    }
    return self;
}

- (void) animateTrunk:(double)time andWindVolume: (double) windVolume {
 randOne = sin(0.2 * time * windVolume) + sin(0.5 * time* windVolume);
 randTwo = sin(0.35 * time* windVolume) - sin(0.15 * time * windVolume);
 flowerHeadPosition.x = FLOWER_POSITION_HOR - FLOWER_TRUNK_WIDTH / 2.0 - randTwo * randOne * FLOWER_CURVITY_CONTROL;
 cp1.x = FLOWER_POSITION_HOR - FLOWER_TRUNK_WIDTH / 2.0 + 10 + randTwo * randOne * 2.0;
 [self.trunkTop setCenter:flowerHeadPosition];
 [self bringSubviewToFront:trunkTop];
}

// Only override drawRect: if you perform custom drawing.
// An empty implementation adversely affects performance during animation.

- (void)drawRect:(CGRect)rect {
    // Drawing code
 CGContextRef c = UIGraphicsGetCurrentContext();

    // Drawing with a GREEN stroke color
 CGContextSetRGBStrokeColor(c, 141.0/255.0, 198.0/255.0, 63.0/255.0, 1.0);
 // Draw them with a FLOWER_TRUNK_WIDTH stroke width so they are a bit more visible.
 CGContextSetLineWidth(c, FLOWER_TRUNK_WIDTH);
 // Draw a bezier curve with end points s,e and control points cp1,cp2
 e = flowerHeadPosition;
 CGContextMoveToPoint(c, s.x, s.y);
 CGContextAddCurveToPoint(c, cp1.x, cp1.y, cp2.x, cp2.y, e.x, e.y);
 CGContextStrokePath(c);
}

-(void)onElementTouch:(id)sender {

}

- (void) onTimeTick:(id)sender {
 static float runningTime = 0.0;
 runningTime += ANIMATION_TIME_STEP;
 [self animateTrunk:runningTime andWindVolume:pow(blowVolume, 5.0)];
}


- (void)dealloc {
 [trunkTop release];
 [delegate release];
    [super dealloc];
}


@end
4

1 に答える 1

0

描画しているビューのサブビューのopaqueプロパティが YES に設定されていますか? もしそうなら (これがデフォルトです)、それらが描画先のビューを完全に覆っている場合、あなたの描画が表示されることは期待できません。

さらに提案して編集:

他のビューに がある場合はopaque=NO、背景色もクリアに設定しますか? Interface Builder で作成した場合は、背景色を「クリア カラー」に設定できます。それらがコードで作成されている場合は、実行できますview.backgroundColor = [UIColor clearColor]

于 2010-09-19T20:55:48.127 に答える