NSScrollView绘图内的图像位于其他视图之上

时间:2011-02-24 02:59:06

标签: cocoa drawing core-graphics nsimage nsscrollview

我有一个自定义的NSView,它位于NSScrollView中的NSSplitView内。自定义视图使用以下绘图代码:

- (void)drawRect:(NSRect)dirtyRect {
    NSGraphicsContext *ctx = [NSGraphicsContext currentContext];
    [ctx saveGraphicsState];

    // Rounded Rect
    NSRect rect = [self bounds];
    NSRect pathRect = NSMakeRect(rect.origin.x + 3, rect.origin.y + 6, rect.size.width - 6, rect.size.height - 6);
    NSBezierPath *path = [NSBezierPath bezierPathWithRoundedRect:pathRect cornerRadius:kDefaultCornerRadius];

    // Shadow
    [NSShadow setShadowWithColor:[NSColor colorWithCalibratedWhite:0 alpha:0.66]
                      blurRadius:4.0
                          offset:NSMakeSize(0, -3)];     
    [[NSColor colorWithCalibratedWhite:0.196 alpha:1.0] set];
    [path fill];
    [NSShadow clearShadow];


    // Background Gradient
    NSGradient *gradient = [[NSGradient alloc] initWithStartingColor:[UAColor darkBlackColor] endingColor:[UAColor lightBlackColor]];
    [gradient drawInBezierPath:path angle:90.0];
    [gradient release];


    // Image
    [path setClip];
    NSRect imageRect = NSMakeRect(pathRect.origin.x, pathRect.origin.y, pathRect.size.height * kLargeImageRatio, pathRect.size.height);
    [self.image drawInRect:imageRect
                  fromRect:NSZeroRect
                 operation:NSCompositeSourceAtop
                  fraction:1.0];

    [ctx restoreGraphicsState];

    [super drawRect:dirtyRect];
}

我尝试了每种不同类型的operation,但图片仍然在NSSplitView的另一半上方,如此:

enter image description here

...而不是在NSScrollView下绘图。我认为这与绘制所有内容而不仅仅是dirtyRect有关,但我不知道如何编辑图像绘制代码以仅绘制dirtyRect中的部分内容。 如何阻止它在顶部绘图,或者只为此NSImage绘制脏矩形?

1 个答案:

答案 0 :(得分:1)

我终于明白了。我不知道它是否是最佳的,但我会在进行性能测试时发现。我只需要使用NSIntersectionRect找出图像rect和脏矩形的交集,然后找出要为NSImage调用绘制的drawInRect:fromRect:operation:fraction:的哪个子部分。

这是重要的部分:

    NSRect imageRect = NSMakeRect(pathRect.origin.x, pathRect.origin.y, pathRect.size.height * kLargeImageRatio, pathRect.size.height);
    [self.image setSize:imageRect.size];

    NSRect intersectionRect = NSIntersectionRect(dirtyRect, imageRect);
    NSRect fromRect = NSMakeRect(intersectionRect.origin.x - imageRect.origin.x,
                                 intersectionRect.origin.y - imageRect.origin.y,
                                 intersectionRect.size.width,
                                 intersectionRect.size.height);
    [self.image drawInRect:intersectionRect
                  fromRect:fromRect
                 operation:NSCompositeSourceOver
                  fraction:1.0];