国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開APP
userphoto
未登錄

開通VIP,暢享免費(fèi)電子書等14項(xiàng)超值服

開通VIP
一步一步學(xué)Silverlight 2系列(5):實(shí)現(xiàn)簡單的拖放功能

一步一步學(xué)Silverlight 2系列(5):實(shí)現(xiàn)簡單的拖放功能

概述

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

本文為系列文章第五篇,利用前面講過的鼠標(biāo)事件處理實(shí)現(xià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è)簡單的界面,用一個(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;
}

效果顯示

最終,完成后的效果如下

拖動(dòng)按鈕

結(jié)束語

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

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
Silverlight4 如何實(shí)現(xiàn)DataContextChanged事件
Silverlight實(shí)用竅門系列:36.Silverlight中播放視頻和打印文檔【附帶...
Silverlight多點(diǎn)觸控中圖形放大縮小
Silverlight and Javascript Interaction | Switch on the Code
快速定位元素
html5版canvas自由拼圖實(shí)例
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服