6

我正在编写一个需要接受文件夹删除的自定义视图。条件是:只接受目录,所以当用户拖动文件时什么都不会发生。

我已经注册了我的观点:

[self registerForDraggedTypes:[NSArray arrayWithObject:NSFilenamesPboardType]];

并且已经实现了基本的拖动协议方法。出于测试目的:

- (NSDragOperation)draggingEntered:(id<NSDraggingInfo>)sender
{
    NSLog("@Drag Entered");
    return NSDragOperationCopy;
}

- (NSDragOperation)draggingUpdated:(id<NSDraggingInfo>)sender
{
    return NSDragOperationCopy;
}

- (void)draggingExited:(id<NSDraggingInfo>)sender
{
    NSLog(@"Dragging Exited");
}

- (BOOL)prepareForDragOperation:(id<NSDraggingInfo>)sender { return YES; }
- (BOOL)performDragOperation:(id<NSDraggingInfo>)sender    { return YES; }

所以它几乎可以正常工作:在视图上拖动光标时会出现一个加号。但是,如果该项目是常规文件,我想避免这种情况。

一旦我得到拖动的路径,我可能需要使用 NSFileManager 来执行此操作(尽管我想知道是否有更简单的方法),但问题是在哪里。我试图在draggingEntered:返回NSDragOperationNone的方法中包含测试权,但没有成功。我正在关注 Apple 文档中的一个片段:

{
    NSPasteboard *pboard = [sender draggingPasteboard];

    if ( [[pboard types] containsObject:NSFilenamesPboardType] ) {
        NSArray *files = [pboard propertyListForType:NSFilenamesPboardType];
        int numberOfFiles = [files count];
        // Perform operation using the list of files
    }
    return YES;
}

我应该在哪里实现这个测试,所以如果拖动文件,光标保持不变?

4

1 回答 1

6

如果粘贴板包含文件,您应该执行测试-draggingEntered:并返回。NSDragOperationNone

但是,由于您还实现‑draggingUpdated:了 ,因此您还需要将文件夹类型的测试添加到该方法中。

目前你总是NSDragOperationCopy‑draggingUpdated:没有测试文件类型的情况下返回,这意味着只要鼠标移动到你的拖动目标中,无论你在‑draggingEntered:.

请注意,实施‑draggingUpdated:是可选的。如果您没有实现具有多个可能的拖动目的地的复杂视图,那么您不需要实现它,只需‑draggingEntered:‑draggingExited:.

于 2011-06-02T02:15:48.417 回答