posts - 118,  comments - 447,  views - 27万

      DeepZoom silverlight的特色功能之一,也同样被加到了windows phone 7中来。这个功能现在应该算是phone7 Ui的主要功能了吧。因为phone7的很多Ui就是DeepZoom开发的,另外在MIX10大会有展出的漫画阅读软件也是由DeepZoom开发的,由此也可以看的出这个功能在phone7上的重要性。

 

一.要开发DeepZoom首先需要 DeepZoom Composer这个在expression下的工具来生成deepzoom图集。

 

二.新建windows phone application,在xaml设计窗口加入以下语句:

<MultiScaleImage x:Name="msi" Width="486" Height="652"  VerticalAlignment="Top" HorizontalAlignment="Left" Margin="-6,0,0,0" />

Phone7中只能用MultiScaleImage来展示DeepZoom图集。

 

三.DeepZoom Composer生成的图集加入到工程中。

四.加入如下代码,以显示图集:

 this.msi.ImageOpenSucceeded += new RoutedEventHandler(msi_ImageOpenSucceeded);

 

void msi_ImageOpenSucceeded(object sender, RoutedEventArgs e)

        {

            Point point = this.msi.ViewportOrigin;

            msi.ViewportWidth = 1;

            msi.ViewportOrigin = new Point(0, -0.3);

        }

 

this.msi.Source = new DeepZoomImageTileSource(new Uri("Assets /dzc_output.xml", UriKind.Relative));

 

五.要让图集移动,缩放,还需要加入MouseMove,LButtonDown,LbuttonUp的响应。

        private void Zoom(double zoomnew, Point p)

        {

            if (zoomnew < 0.5)

                zoomnew = 0.5;

 

            msi.ZoomAboutLogicalPoint(zoomnew / zoom, p.X, p.Y);

            zoom = zoomnew;

        }

好了,运行一下吧,看看是不很有趣!看看效果吧。

 

posted on   小镇  阅读(2358)  评论(17编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
< 2010年5月 >
25 26 27 28 29 30 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示