1

View ControllerにUIViewを追加しました。最初にUIViewに境界線の色を設定しましたが、ビューの境界線がスムーズに見えるようになりました。

ここの下の初期コード

- (id)initWithImage:(UIImage*)image delegate:(id)delegat{
    if ( (self = [super initWithImage:image]) ) {
        self.layer.masksToBounds = YES;
        self.frame = CGRectMake(self.frame.origin.x, self.frame.origin.y, self.frame.size.width+1, self.frame.size.height+1);
        self.contentMode = UIViewContentModeCenter;
        ratio = image.size.height / image.size.width;
        itemType = 2;
        self.userInteractionEnabled =TRUE;
        self.delegate = delegat;
        self.layer.borderColor = [UIColor redColor].CGColor;
        self.layer.borderWidth = 4;
        scaleFactor = 1.0;
        rotateAngle = 0.0;
        fontSize = 22;
        self.contentScaleFactor = 1.0;
        if(image != nil){
            frameWidth = image.size.width;
            frameHeight = image.size.height;
        }else{
            frameWidth = self.frame.size.width;
            frameHeight = self.frame.size.height;    
        }

        [self addGestureRecognizers];
    }    
    return self;
}

ここに画像の説明を入力

ここに回転コードのコードがあります

- (void)rotatePiece:(UIRotationGestureRecognizer *)gestureRecognizer{


    if ([gestureRecognizer state] == UIGestureRecognizerStateBegan || [gestureRecognizer state] == UIGestureRecognizerStateChanged) {
        // To undo the action : store information
        [[UIAppDelegate viewController] storeAction:CHUndoActionTypeRotate item:self];

        [gestureRecognizer view].transform = CGAffineTransformRotate([[gestureRecognizer view] transform], [gestureRecognizer rotation]);
        [gestureRecognizer setRotation:0];
    }

}

これは、ビューを回転させているときに得たものです

ここに画像の説明を入力

4

1 に答える 1

1

これは一見かなり一般的な問題です。あなたが望むのは、境界線をアンチエイリアスにすることです。 ここに解決策のある投稿があり、ここに別の投稿があります。

基本的に、UIImageView を使用して、画像の周りに 1 ピクセルの透明な境界線を追加して、実際の境界線がアンチエイリアスされるようにすることができます。

于 2012-06-29T14:43:35.853 に答える