如何处理 GetDataPresent 让它接受所有派生类型

How to deal with GetDataPresent to let it accept all the derived types(如何处理 GetDataPresent 让它接受所有派生类型)
本文介绍了如何处理 GetDataPresent 让它接受所有派生类型的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在使用 drgevent.Data.GetDataPresent 来确定是否拖动的组件是否可以接受.

I'm using drgevent.Data.GetDataPresent to determine whether the dragged component is acceptable or not.

我有一个问题,我想接受一个特定的类型,比如 SomeType 以及从它派生的所有类型.似乎 GetDataPresent 不支持这样的要求.

I've got a problem which is that I want to accept a specific type say SomeType and all the types that derived from it. Seems GetDataPresent doesn't support such requirement.

有什么想法吗?

推荐答案

只是不要使用 GetDataPresent(),它是样板文件,但您可以按照自己的方式进行操作.实际检索对象并检查您是否对它的类型感到满意:

Just don't use GetDataPresent(), it is boilerplate but you're free to do it your way. Actually retrieve the object and check if you're happy with its type:

    protected override void OnDragEnter(DragEventArgs drgevent) {
        var obj = drgevent.Data.GetData(drgevent.Data.GetFormats()[0]);
        if (typeof(Base).IsAssignableFrom(obj.GetType())) {
            drgevent.Effect = DragDropEffects.Copy;
        }
    }

Base 是基类的名称.虽然 GetFormats() 的使用看起来很奇怪,但这种方法可以保证有效,因为拖动 .NET 对象只会产生 one 格式,即对象类型的显示名称.这也是 GetDataPresent 不能用于派生对象的原因.

Where Base is the name of the base class. While the use of GetFormats() looks odd, this approach is guaranteed to work because dragging a .NET object only ever produces one format, the display name of the type of the object. Which is also the reason that GetDataPresent can't work for derived objects.

这篇关于如何处理 GetDataPresent 让它接受所有派生类型的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)