3

您可以将对象保存到 Visual Studio 中的 settings.settings 文件吗?如果有怎么办?我认为您可以使您的对象可序列化并且它应该持续存在,但是我不确定我是否做得对,即当我尝试取回对象时它始终为空。

这是代码:

    [Serializable()]
    [XmlRoot(ElementName = "LayerTCA", IsNullable = false, Namespace = "http://somesite.com")]
    public class LayerTCA
    {
        //This is a COM object so I don't want to serialize this.
        IFeatureClass featureClass;

        string fullName;
        string basicName;

        public LayerTCA()
        {

        }

        public LayerTCA(IFeatureClass featureClass)
        {
            FeatureClass = featureClass;
        }


        public IFeatureClass FeatureClass
        {
            get { return featureClass; }
            set 
            {
                featureClass = value;
                fullName = featureClass.AliasName;
                basicName = StringHelper.StringAfterLastFullStop(fullName);
            }
        }

        [XmlAttribute(AttributeName = "BasicName")]  
        public string BasicName
        {
            get { return basicName; }
            set { basicName = value; }
        }


        [XmlAttribute(AttributeName = "FullName")]  
        public string FullName
        {
            get { return fullName; }
            set { fullName = value; }
        }

        public override string ToString()
        {
            return FullName;
        }

    }
4

1 回答 1

1

我会使用一个 IFeatureClassName 的成员变量。构造函数将接受 IFeatureclass,然后将要素类转换为 IDataset 并将成员变量设置为 IDataset.FullName。这将是一个 IName。所有 IName 对象都可以通过 IPersistStream 持久化。虽然不能直接序列化为 xml,但可以将 IPersistStream 对象写入 byte[](通过 MemoryBlobStream)。不记得 byte[] 是否可以通过 XmlAttribute 公开,可能应该使用 base64。也可能有一个 Open 方法,只需在包含的成员要素类名称变量上调用 IName.Open,返回一个 IFeatureclass。

更新:这里有一些代码可能有助于将要素类名称转换为字符串。

public static void TestIt(IFeatureClass fc)
{
    string guidplusbase64Name = GetFullName((IDataset)fc);
    Debug.Print(guidplusbase64Name);
    IFeatureClass fc2 = OpenDataset(guidplusbase64Name) as IFeatureClass;
    Debug.Print(fc2.AliasName);            
}

public static string GetFullName(IDataset ds)
{
    IPersistStream ps = ds.FullName as IPersistStream;
    Guid g;
    ps.GetClassID(out g);            
    IMemoryBlobStream mbs = new MemoryBlobStreamClass();
    ps.Save(mbs,0);
    object bytes;
    ((IMemoryBlobStreamVariant)mbs).ExportToVariant(out bytes);            
    return String.Format("{0};{1}",g,Convert.ToBase64String((byte[])bytes));
}

public static IDataset OpenDataset(string guidplusbase64Name)
{
    int idx = guidplusbase64Name.IndexOf(";");
    string base64Name = guidplusbase64Name.Substring(idx+1);
    string guidString = guidplusbase64Name.Substring(0, idx);

    byte[] bytes = Convert.FromBase64String(base64Name);
    IMemoryBlobStream mbs = new MemoryBlobStreamClass();
    ((IMemoryBlobStreamVariant)mbs).ImportFromVariant(bytes);
    Type t = Type.GetTypeFromCLSID(new Guid(guidString));
    IName n = Activator.CreateInstance(t) as IName;
    ((IPersistStream)n).Load(mbs);
    IDataset ds = n.Open() as IDataset;
    return ds;
}

(更新为与任何 IDataset 一起使用,而不仅仅是要素类)(更新 2:连接 clsid 允许它与任何数据集一起使用,以前的版本是为要素类名称硬连线的)

不要问我为什么 ESRI 没有开始实施IName.NameString

NameString 属性保留供将来使用。实现时,它将返回名称对象的位置组件的字符串表示形式,该名称对象可能由应用程序持久化。

于 2010-06-16T14:18:53.703 回答