一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

一步一步學(xué)Silverlight :實(shí)現(xiàn)簡(jiǎn)單的拖放功能

概述

Silverlight 2 Beta 1版本發(fā)布了,無論從Runtime還是Tools都給我們帶來了很多的驚喜,如支持框架語言Visual Basic, Visual C#, IronRuby, IronPython,對(duì)JSON、Web Service、WCF以及Sockets的支持等一系列新的特性。《一步一步學(xué)Silverlight 2系列》文章帶您快速進(jìn)入Silverlight 2開發(fā)。

本文為系列文章第五篇,利用前面講過的鼠標(biāo)事件處理實(shí)現(xiàn)簡(jiǎn)單的拖放功能。

準(zhǔn)備XAML

在實(shí)現(xiàn)拖放功能中,分為三個(gè)步驟:

1.按下鼠標(biāo),觸發(fā)MouseLeftButtonDown事件,選擇要拖動(dòng)的對(duì)象。

2.移動(dòng)鼠標(biāo),觸發(fā)MouseMove事件,移動(dòng)選擇的對(duì)象。

3.放開鼠標(biāo),觸發(fā)MouseLeftButtonUp事件,停止捕捉事件。

做一個(gè)簡(jiǎn)單的界面,用一個(gè)按鈕來顯示拖放,如下XAML聲明:

<Canvas Background="#46461F">    <Button        MouseLeftButtonDown="OnMouseDown"        MouseMove="OnMouseMove"       MouseLeftButtonUp="OnMouseUp"        Canvas.Left="50" Canvas.Top="50" Background="Red"       FontSize="18"       Width="160" Height="80">        <Button.Content>            <StackPanel Orientation="Horizontal" HorizontalAlignment="Center"                        VerticalAlignment="Center">                <Image Source="smile_6.png"></Image>                <TextBlock Text="拖動(dòng)我" VerticalAlignment="Center" Margin="10"></TextBlock>            </StackPanel>        </Button.Content>    </Button></Canvas>

這里為了界面顯示效果,使用了控件模板,后續(xù)會(huì)專門講到。

 

 

開始拖放操作

開始拖放操作,實(shí)現(xiàn)MouseLeftButtonDown事件處理程序,用兩個(gè)全局變量來記錄當(dāng)前鼠標(biāo)的位置和鼠標(biāo)是否保持移動(dòng)。

bool trackingMouseMove = false;Point mousePosition;void OnMouseDown(object sender, MouseButtonEventArgs e){    FrameworkElement element = sender as FrameworkElement;    mousePosition = e.GetPosition(null);    trackingMouseMove = true;    if (null != element)    {        element.CaptureMouse();        element.Cursor = Cursors.Hand;    }}

移動(dòng)對(duì)象

移動(dòng)對(duì)象,實(shí)現(xiàn)MouseMove事件處理程序,計(jì)算元素的位置并更新,同時(shí)更新鼠標(biāo)的位置。

void OnMouseMove(object sender, MouseEventArgs e){    FrameworkElement element = sender as FrameworkElement;    if (trackingMouseMove)    {        double deltaV = e.GetPosition(null).Y - mousePosition.Y;        double deltaH = e.GetPosition(null).X - mousePosition.X;        double newTop = deltaV + (double)element.GetValue(Canvas.TopProperty);        double newLeft = deltaH + (double)element.GetValue(Canvas.LeftProperty);        element.SetValue(Canvas.TopProperty, newTop);        element.SetValue(Canvas.LeftProperty, newLeft);        mousePosition = e.GetPosition(null);    }}

完成拖放操作

完成拖放操作,實(shí)現(xiàn)MouseLeftButtonUp事件處理程序。

void OnMouseUp(object sender, MouseButtonEventArgs e){    FrameworkElement element = sender as FrameworkElement;    trackingMouseMove = false;    element.ReleaseMouseCapture();    mousePosition.X = mousePosition.Y = 0;    element.Cursor = null;}

效果顯示

最終,完成后的效果如下

TerryLee_Silverlight2_0035

拖動(dòng)按鈕

TerryLee_Silverlight2_0036

結(jié)束語

本文實(shí)現(xiàn)了一個(gè)簡(jiǎn)單的拖放功能(示例來自于Silverlight 2 SDK),點(diǎn)擊下載文本示例代碼。

NET技術(shù)一步一步學(xué)Silverlight :實(shí)現(xiàn)簡(jiǎn)單的拖放功能,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产成人精品免费视频网页大全 | 国产中日韩一区二区三区 | 四虎永久地址4hu紧急入口 | 95视频在线观看在线分类h片 | 中文字幕123区 | 色哟哟www视频在线观看高清 | 精品伊人久久大线蕉色首页 | 夜夜综合 | 国内精品久久久久久久久野战 | 色女生影院 | 国产精品第1页在线播放 | 国产精品美女久久久久网 | 加勒比视频网站 | 国产在线观看精品一区二区三区91 | 日韩欧美激情视频 | 自拍偷自拍亚洲精品被多人伦好爽 | 91短视频版在线观看免费 | 日本人真淫视频一区二区三区 | 凹凸精品视频分类国产品免费 | 欧美久久精品一级c片片 | 亚洲国产精品日韩高清秒播 | 精品色哟哟视频在线观看 | 久草视频一区 | 亚洲国产日产无码精品 | 亚洲图片激情小说 | 欧美中文小说在线观看 | 亚洲黄色在线观看 | 久久伊人精品 | 日韩免费视频一区 | 美女特黄| 成人影院vs一区二区 | 久久久久久久99视频 | 最新国产精品亚洲 | 日本一区二区三区在线 视频观看免费 | 综合激情区视频一区视频二区 | 欧美日韩国产亚洲一区二区三区 | 亚洲综合激情另类小说区 | 中文字幕在线视频网 | 美女视频黄视频 | 成人嗯啊视频在线观看 | 伊人狼人久久 |