中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術文檔 > 多媒體制作 > Silverlight多點觸控中圖形放大縮小
用vs2010構(gòu)建Silverlight4應用程序 回到列表 自定義Silverlight右鍵菜單
 Silverlight多點觸控中圖形放大縮小

作者:bluehearts 時間: 2010-05-26 文檔類型:原創(chuàng) 來自:藍色理想

Silverlight多點觸控中圖形放大縮小

談過了捕捉觸控點、以及透過觸控屏幕來手寫繪圖之后,當然,我們也希望能夠像Surface或是Mobile Phone那樣,能夠用手指直接放大縮小圖形,這一個部分就牽扯到所謂的筆勢(gesture)了。

盡管Silverlight Touch API中并沒有直接支持筆勢,但我們還是可以透過先前介紹過的API來實現(xiàn)相關的行為。

從概念上來看,當我們要實現(xiàn)用兩個觸控點來縮放圖形時,整個概念如下:

假設場景中有多個觸控點,其中有兩個觸控點同時點選在某一個對象上,并且開始拖曳(Move),而拖曳的過程中兩個觸控點的距離D愈來愈遠,我們就視為用戶要將圖形放大,反之,若兩點的距離愈來愈近,我們則視為圖形縮小。

在這個概念下,我們需要判斷并處理幾個狀況:

  1. 是否有兩個觸控點同時點在一個對象上。
  2. 這兩個觸控點移動時,取得觸控點之間的距離D。
  3. 在觸控點移動時,透過兩點距離D,來調(diào)整被觸控對象的大小。

請參考先前的程序一,在先前實作的功能中,我們僅實現(xiàn)了拖曳的功能,現(xiàn)在我們看一下『Case TouchAction.Move』部分:

view plaincopy to clipboardprint?
Case TouchAction.Move '當動作為移動
If p.Action = TouchAction.Move Then
'是否還有其他點在同一個對象身上?
If isMultiPoints(p.TouchDevice.DirectlyOver, e) Then
'縮放
'如果第一點是空值
If ElementLastDistance(i) = 0 Then
ElementLastDistance(i) = getFirst2PointsDistance(p.TouchDevice.DirectlyOver, e)
Else
Dim offset As Integer = getFirst2PointsDistance(p.TouchDevice.DirectlyOver, e) - ElementLastDistance(i)
ElementLastDistance(i) = getFirst2PointsDistance(p.TouchDevice.DirectlyOver, e)
'rectangle
If element.GetType() Is GetType(Image) Then
CType(element, Rectangle).Height = CType(element, Rectangle).Height * (1 + offset / SenseValue)
CType(element, Rectangle).Width = CType(element, Rectangle).Width * (1 + offset / SenseValue)
End If
End If
Else
'移動
'取得新坐標
Dim x, y As Integer
x = p.Position.X - originalPointPosistions(i).X
y = p.Position.Y - originalPointPosistions(i).Y
If element IsNot Nothing Then
element.SetValue(Canvas.LeftProperty, originalElementPosistions(i).X + x)
element.SetValue(Canvas.TopProperty, originalElementPosistions(i).Y + y)
End If
End If
End If
Case TouchAction.Move '當動作為移動
If p.Action = TouchAction.Move Then
'是否還有其他點在同一個對象身上?
If isMultiPoints(p.TouchDevice.DirectlyOver, e) Then
'縮放
'如果第一點是空值
If ElementLastDistance(i) = 0 Then
ElementLastDistance(i) = getFirst2PointsDistance(p.TouchDevice.DirectlyOver, e)
Else
Dim offset As Integer = getFirst2PointsDistance(p.TouchDevice.DirectlyOver, e) - ElementLastDistance(i)
ElementLastDistance(i) = getFirst2PointsDistance(p.TouchDevice.DirectlyOver, e)
'rectangle
If element.GetType() Is GetType(Image) Then
CType(element, Rectangle).Height = CType(element, Rectangle).Height * (1 + offset / SenseValue)
CType(element, Rectangle).Width = CType(element, Rectangle).Width * (1 + offset / SenseValue)
End If
End If
Else
'移動
'取得新坐標
Dim x, y As Integer
x = p.Position.X - originalPointPosistions(i).X
y = p.Position.Y - originalPointPosistions(i).Y
If element IsNot Nothing Then
element.SetValue(Canvas.LeftProperty, originalElementPosistions(i).X + x)
element.SetValue(Canvas.TopProperty, originalElementPosistions(i).Y + y)
End If
End If
End If

我們在程序代碼當中加入了幾個動作,分別是判斷同一個對象是否被兩個以上的觸控點所點選,以及這兩個觸控點之間的距離,接著,再透過這兩個觸控點之間的距離來動態(tài)調(diào)整Image對象的大小,就形成我們需要的效果了。

總的來說,Silverlight中的Multi-Touch技術相較而言并不困難,雖然沒有龐大的.NET Framework作為后盾,但簡單好用的Touch API也足以讓我們建構(gòu)出不錯的Web/RIA應用程序,而具體的實現(xiàn)方式就有賴開發(fā)人員的設計了。

總的來說,Silverlight作為第一個支持Multi-Touch功能的RIA/Web應用程序開發(fā)技術,一舉將因特網(wǎng)應用程序的應用層面,擴展到另一個領域,讓應用程序的價值大增,也讓開發(fā)人員能夠發(fā)揮更多的創(chuàng)意。

本文鏈接:http://www.95time.cn/tech/multimedia/2010/7629.asp 

出處:藍色理想
責任編輯:bluehearts

◎進入論壇RIA設計與應用版塊參加討論

相關文章 更多相關鏈接
自定義Silverlight右鍵菜單
Blend基礎:布局控件
Blend基礎:項目與層次
VS 2010 Beta與Silverlight的更新
Silverlight應用技術完全指南
作者文章 更多作者文章
用vs2010構(gòu)建Silverlight4應用程序
VS2010簡體中文版發(fā)布
微軟新商用平臺運營方式轉(zhuǎn)向云計算
創(chuàng)意精英主題沙龍 成都/重慶站招募
云計算的七個最佳建議
關鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設計比賽 網(wǎng)頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設計大賽開啟
國際體驗設計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule

藍色理想版權申明:除部分特別聲明不要轉(zhuǎn)載,或者授權我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設計作品,如需使用,請與原作者聯(lián)系,版權歸原作者所有,文章若有侵犯作者版權,請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關法律法規(guī)
·承擔一切因您的行為而直接或間接導致的民事或刑事法律責任
·本站評論管理人員有權保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2