Какао: используя NSградиент как маску для рисования под ним

StackOverflow https://stackoverflow.com/questions/3103699

Вопрос

Я пытаюсь нарисовать отражение формы, используя какао. Я уже применил NSAffineTransform и успешно перерисовывал форму, но теперь я не могу понять, как нарисовать на нее альфа -маску. Я использую NSCompositeDestinationOut операция, но это дает мне нежелательный результат:Alt Text http://img687.imageshack.us/img687/2417/capturedcran20100623094.png

Я не совсем уверен, как это исправить - мне нужно это сделать Таким образом, градиент действует только как альфа -маска и фактически не отображается. Отказ Я использую неправильный режим композиции?

Спасибо! Вот код градиента, если это необходимо:

- (void)fadeOutRect:(NSRect)rect {
    [NSGraphicsContext saveGraphicsState];
    [[NSGraphicsContext currentContext] setCompositingOperation:NSCompositeDestinationOut];

    NSGradient *gradient = [[NSGradient alloc] initWithColorsAndLocations:
                            [[NSColor blackColor] colorWithAlphaComponent:0.5], 0.0,
                            [[NSColor blackColor] colorWithAlphaComponent:1.0], 0.8, nil];
    [gradient drawInRect:NSMakeRect(rect.origin.x, rect.origin.y + rect.size.height - ( PILL_HEIGHT * 2 ),
                                    rect.size.width, PILL_HEIGHT) angle:270];

    [NSGraphicsContext restoreGraphicsState];
}
Это было полезно?

Решение

Ага. Вот пример кода, который мы используем для этого. Он использует исходное изображение и имеет немного забавного бизнеса с масштабным фактором, но вы должны иметь возможность использовать базовую структуру и выбор композиции, чтобы делать то, что вам нужно. (Этот код находится в блоке [ReflectionImage Lockfocus], и я - это то, что мы делаем отражение.)

// Draw our mask into the image
NSGradient* fade = [[NSGradient alloc] initWithStartingColor:[NSColor colorWithCalibratedWhite:1.0 alpha:0.5]
                                                 endingColor:[NSColor clearColor]];
[fade drawFromPoint:NSMakePoint(0.0, size.height)
            toPoint:NSMakePoint(0.0, 0.0)
            options:0];

// Composite the original image, upside-down
NSAffineTransform* flipper = [NSAffineTransform transform];
[flipper scaleXBy:1.0 yBy:-1.0];
[flipper concat];
[self drawInRect:NSMakeRect(0.0, -1.0*size.height, size.width, size.height)
        fromRect:NSMakeRect(0.0, 0.0, self.size.width, size.height / scaleFactor)
       operation:NSCompositeSourceIn fraction:1.0];
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top