在Silverlight中,使用XAML剪贴画的正确方法是什么?

在Silverlight中,使用XAML剪贴画的正确方法是什么?,第1张

概述假设我在XAML中为我的Silverlight应用程序构建了一些剪贴画,或者从 http://www.xamalot.com下载它,在我的应用程序中使用它的最佳方法是什么? 是否最好为每件艺术品创建用户控件?或者有更好的方法可以从资源字典中引用它吗? 更新: 提供的答案非常详细,似乎暗示使用它的目的远远超出我的想象.我真的只是想知道消费XAML剪贴画的最佳方式,用作(比如)工具栏上的按钮. 有一个 假设我在XAML中为我的Silverlight应用程序构建了一些剪贴画,或者从 http://www.xamalot.com下载它,在我的应用程序中使用它的最佳方法是什么?

是否最好为每件艺术品创建用户控件?或者有更好的方法可以从资源字典中引用它吗?

更新:

提供的答案非常详细,似乎暗示使用它的目的远远超出我的想象.我真的只是想知道消费XAML剪贴画的最佳方式,用作(比如)工具栏上的按钮.

解决方法 有一个更好的办法.

你可以为剪贴画的每个片段创建一个单独的文件,但不是网站使用的包装器,直接在资源字典中的Canvas实例,而不是他最好的前进方式.
我们将从ResourceDictionary开始,但看起来像这样: –

<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"                    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"                    xmlns:local="clr-namespace:YourApplication">    <ControlTemplate targettype="local:Xamlimage" x:Key="SomeImage">        <VIEwBox>            <Canvas> <!-- this the toplevel canvas from the site or your design -->            </Canvas>        </VIEwBox>    </ControlTemplate></ResourceDictionary>

这样做有两件事,首先它使用ControlTemplate来包含图像,当图像可以被多次使用时,例如当图像被用作图标时,这是一种更有效的存储形式.

其次,它使用了VIEwBox,它提供了基于矢量的图形的承诺,它允许将图像缩放到指定的大小.

您需要向项目添加一个新的模板化自定义控件并将其命名为Xamlimage.你不需要做任何事情,它只需要存在.

暂时让我们将这个资源字典添加到App.Xaml(这不太可能保留在哪里).

        
            
                
            
         
    

现在,您可以使用以下方法将此图像放在页面中: –

<local:Xamlimage Template="{StaticResource contactnew}"  />

现在有几种方法可以取决于你的真实意图和数量,我可以根据情况进行详尽的评论.所以采取两个极端……

如果您只想要从中选择一些图像,则可以创建更多文件并将其添加到app.xaml的MergedDictionarIEs中.然而,最大的缺点是所有这些图像Xamls在应用程序启动时被解析和加载,这可能是不可取的.

另一方面,你可能有一个大型的分类Xaml剪贴画库.在这种情况下,您需要将它们放在文件夹结构中,并为每个文件夹包含一个标准大小的缩略图png.一个Xml文件,用作目录,然后根据需要按需加载Xaml文件.在这种情况下,您可以从文件中删除ResourceDictionary并将ControlTemplate作为根元素,使用XamlReader加载模板,然后将模板缓存在您自己的字典中(可能作为目录实现的一部分).

总结

以上是内存溢出为你收集整理的在Silverlight中,使用XAML剪贴画的正确方法是什么?全部内容,希望文章能够帮你解决在Silverlight中,使用XAML剪贴画的正确方法是什么?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1004802.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存