Giáo trình giảng dạy Silverlight 2

Tài liệu Giáo trình giảng dạy Silverlight 2: GIÁO TRÌNH GIẢNG DẠY SILVERLIGHT 2 Nhóm tác giả thuộc công ty Infoway: Phạm Chí Cường Trần Duy Biên Trần Duy Long Website: www.infomap.vn Email: Contact@infoway.com.vn Infoway Solutions MỤC LỤC 2 MỤC LỤC: Chương I: Tổng quan về silverlight 1. Vì sao lại có silverlight? 2. Silverlight là gì 3. Các đặc tính của silverlight 3.1. Sự kết hợp của WPF và XAML 3.2. Mở rộng cho ngôn ngữ kịch bản 3.3. Sự tích hợp với các ứng dụng đã có 3.4. Sử dụng mô hình ngôn ngữ lập trình trên nền tảng .Net Framework và các công cụ để kết hợp 3.5. Hỗ trợ mạng 3.6. Hỗ trợ ngôn ngữ tích hợp truy vấn (LINQ) 4. Kiến trúc tổng thể và các mô hình lập trình của Silverlight 4.1 . Kiến trúc và các thành phần 4.2 . Các mô hình lập trình của silverlight 5. Khả năng hỗ trợ trình duyệt, hệ điều hành và các công nghệ liên quan 5.1. Hỗ trợ của hệ điều hành và trình duyệt 5.2. Các công nghệ và công cụ liên quan của silverlight 6. Hướng dẫn cài đặt và sử dụng công c...

pdf112 trang | Chia sẻ: Khủng Long | Lượt xem: 1156 | Lượt tải: 0download
Bạn đang xem trước 20 trang mẫu tài liệu Giáo trình giảng dạy Silverlight 2, để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên
GIÁO TRÌNH GIẢNG DẠY SILVERLIGHT 2 Nhĩm tác giả thuộc cơng ty Infoway: Phạm Chí Cường Trần Duy Biên Trần Duy Long Website: www.infomap.vn Email: Contact@infoway.com.vn Infoway Solutions MỤC LỤC 2 MỤC LỤC: Chương I: Tổng quan về silverlight 1. Vì sao lại cĩ silverlight? 2. Silverlight là gì 3. Các đặc tính của silverlight 3.1. Sự kết hợp của WPF và XAML 3.2. Mở rộng cho ngơn ngữ kịch bản 3.3. Sự tích hợp với các ứng dụng đã cĩ 3.4. Sử dụng mơ hình ngơn ngữ lập trình trên nền tảng .Net Framework và các cơng cụ để kết hợp 3.5. Hỗ trợ mạng 3.6. Hỗ trợ ngơn ngữ tích hợp truy vấn (LINQ) 4. Kiến trúc tổng thể và các mơ hình lập trình của Silverlight 4.1 . Kiến trúc và các thành phần 4.2 . Các mơ hình lập trình của silverlight 5. Khả năng hỗ trợ trình duyệt, hệ điều hành và các cơng nghệ liên quan 5.1. Hỗ trợ của hệ điều hành và trình duyệt 5.2. Các cơng nghệ và cơng cụ liên quan của silverlight 6. Hướng dẫn cài đặt và sử dụng cơng cụ Silverlight 2 trên Visual studio 2008 6.1. Các bước cài đặt cơng cụ silverlight 2 7. Các ví dụ thực hành 7.1. Chương trình đầu tiên “Hello World” 8. Tài liệu tham khảo Chương II: XAML và Layout 1. Tổng quan về XAML 1.1. Xaml là gì? 1.2. Khai báo đối tượng 1.3. Thiết lập đặc tính cho đối tượng 1.4. Root elements và namespace trong XAML 1.5. Sự kiện 1.6. 2. Các namescope trong XAML 3. Sử dụng XAMLReader.Load 4. XAML và các Custom class 5. XAML và Type Converter 6. Layout 6.1. Canvas 6.2. StackPanel 6.3. Grid Infoway Solutions MỤC LỤC 3 Chương III: Sử dụng Silverlight trên Expression Blend và Visual Studio 2008 1. Giới thiệu về các cơng cụ phát triển Expression Blend 2 kết hợp với VS2008 1.1. Expression Blend làm việc như thế nào? 1.2. Những tính năng cĩ được từ Expression Blend 2. Bắt đầu nhanh với Silverlight 2 trên Expression Blend 2 2.1. Tạo một Project cho ứng dụng Silverlight 2 2.2. Vẽ khuơn hình (Shape) trên ứng dụng Silverlight 2.3. Thiết kế Control trên ứng dụng Silverlight 3. Xây dựng chương trình Silverlight 2 với Expression Blend và Visual Studio 2008Triển khai ứng dụng Chương IV: Các Control và User control trong Silverlight 1. Giới thiệu về các control phổ biến của Silverlight SDK tích hợp trong VS2008 2. Các Control Phổ biến trong Silverlight 2 3. User Control trong Visual Studio 2008 Chương V: Xử lý đồ họa trên Silverlight 1. Giới thiệu 2. Shapes and Drawing 2.1. Ellipse 2.2. Line 2.3. Path 2.4. Polygon 2.5. Polyline 2.6. Rectangle 3. Geometries 3.1. EllipseGeometry 3.2. PathGeometry 3.3. GeometryGroup 4. Brushes 3.1. Solid Color 3.2. Gradient 3.3. Images 3.4. Video 3.5. Deep Zoom Chương VI: Media và Animation 1. Animation 1.1. Storyboard 1.2. Key-Frame Animations Infoway Solutions MỤC LỤC 4 1.3. Double Animation 1.4. Color Animation 1.5. Point Animation 2. Media 2.1. MediaElement Object 2.2. Controlling Media Playback Interactively 2.3. Timeline Markers 2.4. Server-Side Playlist Ch ương VII: Làm việc với cơ sở dữ liệu trong Silverlight 1. Giới thiệu một vài cơng nghệ để truy cập dữ liệu trong Silverlight 2. Sử dụng Data Binding 3. Sử dụng Isolated Storage 4. Khái quát về làm việc với dữ liệu XML 5. Truy cập dữ liệu SQL Server với WCF Chương VIII: Giao tiếp mạng với silverlight 1. Giao tiếp HTTP và bảo mật trong Silverlight 1.1. Mặc định hỗ trợ giao thức HTTP 1.2. Kịch bản giao tiếp HTTP 1.3. Giao tiếp trong cùng một domain 1.4. Giao tiếp Cross-domain 1.5. Thiết lập triệu gọi HTTP 2. Các hạn chế trong truy cập mạng với silverlight 3. Truy cập web service trong silverlight 3.1. Bảo mật cho truy cập Service 3.2. Tạo một Service vượt qua phạm vi domain 4. Làm việc với socket 4.1. Hỗ trợ giao thức mạng 4.2. Lập trình mạng cơ bản với Socket 5. Mã hĩa dữ liệu của service Chương IX: Hiệu suất hoạt động trong ứng dụng Silverlight 1. Làm thế nào để chương trình của bạn chạy nhanh và ổn định 1.1. Thử nghiệm trên nhiều hệ điều hành và trình duyệt 1.2. Đặt EnableFrameRateCounter cho đúng trong thời gian phát triển 1.3. Sử dụng Transparent Background 1.4. Tránh việc sử dụng các kịch bản làm biến đổi kích cỡ font của Text 1.5. Tránh sử dụng chế độ Windowless 1.6. Sử dụng Visibility thay cho việc sử dụng Opacity trong rất nhiều trường hợp khơng cần đến sự cĩ mặt của Opacity 1.7. Silverlight sử dụng Multi-Core trong Rendering và Media Infoway Solutions MỤC LỤC 5 1.8. Trong chế độ Full-Screen, ẩn những đối tượng khơng sử dụng 1.9. Tránh sử dụng thuộc tính Width và Height đối với đối tượng MediaElement 1.10. Tránh sử dụng thuộc tính Width và Height đối với đối tượng Path 1.11. Nguy cơ đổ vỡ khi CPU sử ly cường độ lớn cơng việc 1.12. Nguy cơ đổ vỡ đối với ứng dụng cĩ những Package lớn 1.13. Sử dụng Double.ToString(CultureInfo.InvariantCulture) hiệu quả hơn Double.ToString() 1.14. 2. Sử dụng Background Worker 2.1. Bắt đầu với việc tạo một BackGroundWorker 2.2. Tạo một Event handler cho background worker bởi DoWork event 2.3. Tạo một event handler cho sự kiện ProgressChanged của backgroundworker 2.4. Tạo một sự kiện cho RunWorkerCompleted 2.5. Bổ xung sự kiện vào BackGroundWorker 2.6. Bắt đầu chạy background gọi bởi thủ tục RunWorkerAsync. 2.7. Hủy bỏ hoạt động của background gọi bởi thủ tục CancelAsync. Infoway Solutions CHƯƠNG I: TỔNG QUAN VỀ SILVERLIGHT CHƯƠNG I: TỔNG QUAN VỀ SILVERLIGHT 1 Vì sao lại cĩ Silverlight? Sự khĩ khăn của các doanh nghiệp khi xây dựng chiến lược Web Ngày nay khi phát triển các ứng dụng trên web các doanh nghiệp phần mềm thường đau đầu với những khĩ khăn về sự hỗ trợ trên trình duyệt và hệ điều hành. Điều họ muốn là với những ngơn ngữ và cơng cụ phát triển đã vốn quen thuộc từ trước đến giờ đều cĩ thể làm cho họ những ứng dụng chạy tốt trên mọi nền tảng, mọi trình duyệt. Silverlight ra đời như một cơng nghệ phù hợp cho phép họ làm được những việc như thế. Nếu bạn đã quen thuộc với cơng nghệ .Net Framework thì khi tiếp cận với Silverlight bạn sẽ tích kiện được rất nhiều thời gian và chi phí cho cơng nghệ web mới Nhu cầu cần thiết của thế giới đa phương tiện Các cơng nghệ plug-in trên web trước đây khơng cho phép bạn truyền tải những dữ liệu hình ảnh chất lượng cao như 720p HDTV, Trong khi chất lượng đường truyền mạng ngày nay đang ngày càng tốt hơn và nhu cầu được xem những video chất lượng cao cũng tăng lên thì sự ra đời của Silverlight đã đem đến cho người đam mê thế giới đa phương tiện một sự thỏa mãn thật sự. 2 Silverlight là gì? Silverlight là một dạng plug-in dựa trên cơng nghệ của Microsoft .Net, nĩ độc lập với đa nền tảng và đa trình duyệt, nĩ cho phép phát triển các ứng dụng đa phương tiện đặc biệt là các ứng dụng trên web. Silverlight cung cấp một mơ hình lập trình lập trình mềm dẻo và đồng nhất, nĩ hỗ trợ Ajax, Python, Ruby và các ngơn ngữ lập trình .Net như Visual basic, C#. Khả năng đa phương tiện của silverlight thể hiện ở mức độ truyền tải âm thanh và hình ảnh chất lượng cao một cách nhanh chĩng và hiệu quả trên tất cả các trình duyệt chính như Internet Explorer, Firefox, Safari. Infoway Solutions CHƯƠNG I: TỔNG QUAN VỀ SILVERLIGHT 2 Với việc sử dụng Expression Studio và Visual Studio, các nhà thiết kế và phát triển cĩ thể hợp tác một cách hiệu quả hơn bằng cách sử dụng chính kỹ năng của họ cĩ hiện nay để làm phát triển các sản phẩm web tương lai “Light up the web”. 3 Các đặc tính của Silverlight Silverlight kết hợp nhiều cơng nghệ vào một nền tảng phát triển, nĩ cho phép bạn được lựa chọn nhiều cơng cụ và ngơn ngữ lập trình thích hợp để giải quyết bài tốn của bạn. Silverlight cung cấp các tính năng sau: 3.1 Sự kết hợp của WPF và XAML. Silverlight là một gĩi nhỏ của cơng nghệ Windows Presentation Foundation (WPF). Nĩ được mở rộng nhiều hơn các Element trong trình duyệt để tạo giao diện người dùng. PWF cho phép bạn tạo ra đồ họa 3 chiều, hình ảnh động, đa phương tiện và nhiều tính năng phong phú khác trên máy khách. XAML (Extensible Application Markup Language) cung cấp các cú pháp đánh dấu đặc trưng cho việc tạo các Element. 3.2 Mở rộng cho ngơn ngữ kịch bản Silverlight cung cấp việc mở rộng cho các ngơn ngữ kịch bản (Javascript) ở một số các trình duyệt phổ biến để thể hiện việc trình bày giao diện và thao tác người dùng một cách phong phú hơn. 3.3 Sự tích hợp với các ứng dụng đã cĩ Silverlight tích hợp liền mạch với ngơn ngữ javascript và mã Ajax của ASP.Net để bổ sung các chức năng bạn đã xây dựng được. Bạn cĩ thể tạo những tài nguyên trên nền máy chủ cĩ trong ASP.NET và sử dụng các khả năng của Ajax trong ASP.NET để tương tác với tài nguyên trên nền máy chủ đĩ mà khơng làm gián đoạn người dùng. 3.4 Sử dụng mơ hình ngơn ngữ lập trình trên nền tảng .Net Framework và các cơng cụ để kết hợp. Bạn cĩ thể tạo các ứng dụng trên nền tảng Silverlight và sử dụng các ngơn ngữ động như InronPython cũng như là các ngơn ngữ C# và Visual Basic. Bạn cũng cĩ thể sử dụng các cơng cụ phát triển như Visual Studio để tạo ứng dụng trên nền tảng Silverlight 3.5 Hỗ trợ mạng Silverlight bao gồm các hỗ trợ cho HTTP qua TCP. Bạn cĩ thể kết nối tới các dịch vụ của WCF, SOAP, hoặc ASP.NET AJAX và nhận về các định dạng theo cấu trúc XML, JSON hay dữ liệu RSS. 3.6 Hỗ trợ ngơn ngữ tích hợp truy vấn (LINQ) Điều này cho phép bạn truy cập dữ liệu bằng cách sử dụng cú pháp trực quan tự nhiên và mạnh mẽ, được gõ bởi các đối tượng cĩ trong các ngơn ngữ .Net Framework. Infoway Solutions CHƯƠNG I: TỔNG QUAN VỀ SILVERLIGHT 3 4 Kiến trúc tổng thể và các mơ hình lập trình của Silverlight 4.1 Kiến trúc và các thành phần Về cơ bản Silverlight là một nền tảng thống nhất của nhiều thành phần khác nhau. Tuy nhiên chúng tơi nhĩm lại các thành phần chính của silverlight vào bảng dưới đây. Thành phần Diển tả Nền tảng trình bày cơ sở Các thành phần và dịch vụ hướng tới giao diện người dùng và tương tác người dùng, bao gồm các control cho dữ liệu cho người dùng nhập, thiết bị đa phương tiện, quản lý phân quyền số, trình bày dữ liệu, đồ họa vector, chữ, hình ảnh động. cũng bao gồm XAML để đặc tả việc bố trí giao diện .Net Framework cho silverlight Là một gĩi nhỏ trong .Net Framework, bao gồm các thành phần và cá thư viện, kể cả tương việc tương tác dữ liệu, khả năng mở rộng các control, mạng, garbage collection, và CLR Cài đặt và cập nhật Là thành phần để sử lý các tiến trình cài đặt làm sao để đơn giản hĩa cho lần cài đặt đầu tiên, tiếp sau đĩ chỉ cung cấp cơ chế tự động cập nhật và tương tác ở mức thấp. Dưới đây là hình ảnh mơ tả những thành phần trong kiến trúc của Silverlight cùng với các thành phần và dịch vụ liên quan khác. Core Presentation Components: Tính năng Mơ tả Dữ liệu vào (input) Xử lý dữ liệu đầu vào từ các thiết bị phần cứng như bàn phím, chuột, bảng vẽ Infoway Solutions CHƯƠNG I: TỔNG QUAN VỀ SILVERLIGHT 4 hoặc các thiết bị đầu vào khác Trình bày giao diện người dùng (UI Rendering) Trình bày vector và các đồ hoạ ảnh bitmap, ảnh động, và văn bản Thiết bị nghe nhìn (Media) Các tính năng phát và quản lý một vài thể loại file âm thanh và hình ảnh như .WMP và .MP3 Controls Hỗ trợ mở rộng cho các control để cĩ khả năng tùy chỉnh về kiểu dáng và khuơn mẫu Xếp đặt Layout Cho phép khả năng xếp đặt vị trí động các thành phần giao diện người dùng Trình bày dữ liệu (Data Binding) Cho phép việc kết nối dữ liệu của các đối tượng và các thành phần giao diện người dùng DRM Khả năng Quản lý phân quyền số XAML Cung cấp trình phân tách cho XAML Các lập trình viên cĩ thể tương tác với thành phần nền tảng trình bày cơ sở trên đây bằng cách sử dụng XAML để đặc tả. XAML là một yếu tố quan trọng nhất trong việc tương tác giữa .Net Framwork và các kiểu trình bày Layout, ngồi ra các lập trình viên cũng cĩ thể sử dụng cơ chế quản lý code bên trong để thao tác với lớp trình bày .Net Frame work for Silverlight: Tính năng Mơ tả Data Hỗ trợ ngơn ngữ truy vấn tích hợp (LINQ) và LINQ với đặc tả XML, dễ dang xử lý việc tích hợp và làm việc với dữ liệu từ nhiều nguồn khác nhau. Hỗ trợ việc sử dụng XML và các lớp biên đổi hĩa (serialization) để xử lý dữ liệu Base class library Thuộc thư viện của .Net Framework, nĩ cung cấp các chức năng lập trình chủ yếu như việc xử lý chuỗi, biểu thức chính quy, đầu vào và đầu ra, ánh xạ, tập hợp và tồn cục hĩa. Window Communication Foundation (WCF) Cung cấp các tính năng để đơn giản hĩa việc truy cập dữ liệu từ xa. Cơ chế này bao gồm một đối tượng trình duyệt, HTTP request và HTTP Response, RSS, JSON, POX, và các SOAP Common language runtime (CLR) Cung cấp việc quản lý bộ nhớ, dọn dẹp bộ nhớ thừa, xử lý ngoại lệ Windows Presentation Foundation controls (WPF) Cung cấp các control giầu tính năng như Button, Calendar, CheckBox, DataGrid, DatePicker, HyperlinkButton, ListBox, RadioButton, and ScrollViewer. Dynamic language runtime (DLR) Hỗ trợ việc biên dịch và thi hành với tính năng động của các ngơn ngữ kịch bản như Javascript và IronPython cho các chương trình trên nền tảng Silverlight. 4.2 Các mơ hình lập trình của silverlight Ở phiên bản Silverlight 1.0 cung cấp cho bạn duy nhất một mơ hình lập trình là Javascript API, cho đến phiên bản Silverlight 2.0 đã cung cấp cả hai mơ hình lập trình là Managed API và Javascript API. Trong khi Javascipt API chỉ cho phép bạn gõ mã lệnh Javascript để tương tác với trình duyệt thì Managed API đã sử dụng được cơ chế làm việc của Common Language Infoway Solutions CHƯƠNG I: TỔNG QUAN VỀ SILVERLIGHT 5 Runtime (CLR) và kể cả Dynamic Language Runtime (DLR) để biên dịch và thi chương trình code (C#, VB\) của bạn. 4.2.1 Javascript API Trong một chương trình silverlight nhúng theo kiểu Javascript API, nĩ tải chỉ một trang XAML đơn lẻ thay vì tải một gĩi ứng dụng. Trang XAML này cĩ thể bao gồm các tham chiều URI từ những nguồn bên máy chủ khác như là các đoạn video và hình ảnh. Silverlight nhúng sử dụng XAML để tạo một cây đối tượng cái mà bạn cĩ thể thao tác lập trình với javascript lưu trữ bên trong một trang HTML Javascript API khơng cung cấp một mơ hình ứng dụng cĩ khả năng hỗ trợ các ứng dụng tổ hợp với sự điều hướng bên trong. Tuy nhiên nĩ cho phép làm những kịch bản theo kiểu Splash screan. Bạn cũng cĩ thể làm các sự điều hướng trong Javascript API bằng cách tải lại trang XAML mới hoặc tải lại cả trang web đĩ trong trình duyệt. 4.2.2 Managed API Trong lập trình silverlight theo kiểu Managed API, bạn cĩ thể thao tác lập trình với cả file XAML và file code bên trong. Khi một Silverlight nhúng tải file XAML, nĩ sẽ tạo một cây mơ hình cái mà bạn cũng cĩ thể gõ bằng các mã lệnh bên trong ( thường là C#, Visual basic\). 5 Khả năng hỗ trợ trình duyệt, hệ điều hành và các cơng nghệ liên quan 5.1 Hỗ trợ của hệ điều hành và trình duyệt được mơ tả ở bảng dưới đây Operating system Internet Explorer 7 Internet Explorer 6 Firefox 1.5, 2.x, and 3.x Safari 2.x and 3.x Windows Vista cĩ — cĩ — Windows XP SP2 cĩ cĩ cĩ — Windows XP SP3 cĩ cĩ cĩ — Windows 2000 — cĩ — — Windows Server 2003 (excluding IA-64) cĩ cĩ cĩ — Mac OS 10.4.8+ (PowerPC) — — — — Mac OS 10.4.8+ (Intel-based) — — cĩ Cĩ 5.2 Các cơng nghệ và cơng cụ liên quan của silverlight. Microsoft Expression Blend: Sử dụng cơng cụ này bạn bạn cĩ thể tạo và thay đổi cách xắp xếp trình bày Layer của ứng dụng bằng cách thao tác đến canvas và control trong XAML, làm việc với các chức năng đồ họa, Lập trình với ngơn ngữ Javascript. Visual Studio 2008: Visual Studio cung cấp các cơng cụ hiệu quả cho việc phát triển các ứng dụng cĩ hỗ trợ thao tác code bên tron. Tất cả các phiên bản đã cĩ của Visual Studio đều cĩ khả năng hỗ trợ Silverlight,Tuy nhiên ở phiên bản mới này nĩ cịn hỗ trợ các tính năng đặc Infoway Solutions CHƯƠNG I: TỔNG QUAN VỀ SILVERLIGHT 6 biệt hơn như bao gồm khả năng IntelliSense, debugging và các template cho việc tạo mới một ứng dụng Silverlight. ASP.NET AJAX: Bao gồm tập các Control, Service, và các thư viện cần thiết cho việc tạo và tương tác với nền ứng dụng web Microsoft ASP.NET 3.5 Extensions Preview: Cơng nghệ này cung cấp chức năng thêm để việc tăng cường các ứng dụng ASP.NET AJAX. Nĩ bao gồm 2 control sử dụng hữu ích cho việc xây dựng ứng dụng nền tảng silverlight cũng như là một phần của ứng dụng ASP.NET: - ASP.NET MediaPlayer Server Control - ASP.NET Silverlight Server Control Internet servers: Bao gồm IIS (Microsoft Internet Information Services), và Apache Web server Microsoft Windows Communication Foundation (WCF) services. 6 Hướng dẫn cài đặt và sử dụng cơng cụ Silverlight 2 trên Visual studio 2008 6.1 Các bước cài đặt cơng cụ silverlight 2 - Tải file Silverlight_Tools.exe cĩ trên trang: 8EF6-D60C8EE221ED&displaylang=en - Bạn phải chắc chắn rằng máy tính của bạn đã cài đặt Visual Studio 2008 SP1 - Chạy file Silverlight_Tools.exe, chờ khoảng 1 phút để hiện thị Silverlight tools installation Winzard - Bấm next để đến bước 2, tích chọn “I have read an accept the license terms”. Infoway Solutions CHƯƠNG I: TỔNG QUAN VỀ SILVERLIGHT 7 - Bấm Next để hệ thống tự động kiểm tra tương thích( lưu ý: phải đĩng hết các trình duyệt web) - Để hệ thống cài đặt và hồn thành 7 Các ví dụ thực hành 7.1 Chương trình đầu tiên “Hello World” - Tạo mới một Project: chọn File -> New -> Proeject - Một cửa sổ mới “New Project” hiển ra. Chọn Visual C# (hoặc Visual basic) trong Project types, chọn Silverlight. Phía bên phải cửa sổ cho phép bạn chọn các Templale Infoway Solutions CHƯƠNG I: TỔNG QUAN VỀ SILVERLIGHT 8 - Chún ta chọn Silverlight Application trong Templates - Đặt tên chương trình đầu tiên là “HelloWorld”, tùy chọn Location, bấm OK - Bạn cĩ thể chọn Project Type theo mặc định trong hội thoại Add Silverlight application, bấm OK - Solution mới được tạo ra với 2 project: Silverlight project và web project( dùng để nhúng silverlight tạo bởi silverlight project) Trong thư mục ClientBin của web project (HelloWorld.Web) chứa ứng dụng silverlight được đĩng gĩi dưới dạng file HelloWorld.xap của project silverlight (HelloWorld) Infoway Solutions CHƯƠNG I: TỔNG QUAN VỀ SILVERLIGHT 9 Tồn bộ màn hình ứng dụng đầu tiên của bạn được nhìn thấy như sau - Chúng ta làm 2 phương pháp một là viết code C# trong code ứng dụng, hai là viết trực tiếp trong XAML 7.1.1 Viết chương trình bằng Code C# - Trong file Page.xaml.cs chúng ta bắt đầu với việc tạo một nút theo những dịng lệnh dưới đây // Khai bao button Button myButton; public Page() { InitializeComponent(); // Khởi tạo button myButton = new Button(); //Xác định các thuộc tính cho myButton myButton.Content = "Click Me"; myButton.Height = 25; myButton.Width = 100; myButton.Margin = new Thickness(10, 10, 0, 0); //ðưa myButton vào LayoutRoot LayoutRoot.Children.Add(myButton); - Để tạo sự kiện cho một nút chúng ta cần thêm những dịng lệnh sau vào //thêm phương thức xử lý sự kiện cho myButton myButton.Click += new RoutedEventHandler(myButton_Click); void myButton_Click(object sender, RoutedEventArgs e) { //Hiển thị thơng điệp trên trình duyệt System.Windows.Browser.HtmlPage.Window.Alert("Hello Silverlight World!"); } - Bấm F5 để chạy chương trình Infoway Solutions CHƯƠNG I: TỔNG QUAN VỀ SILVERLIGHT 10 7.1.2 Viết chương trình bằng XAML Lưu ý, với cùng project trên, muốn viết đặc tả bằng XAML tương đương ta cần xĩa bỏ phần mã trình C# cũ đi, vì C# và XAML khơng thể cùng sinh một đối tượng. Trong file Page.xaml ta thêm đoạn mã sau <UserControl x:Class="HelloWorld.Page" xmlns="" xmlns:x="" Width="400" Height="300"> - Gán sự kiện xử lý khi click - Bấm F5 để chạy ứng dụng. Cả hai phương thức viết trên đều cho ra một kết quả như hình vẽ sau 8 Tài liệu tham khảo - Silverlight Deverloper center: - Website chính của Silverlight: Infoway Solutions CHƯƠNG II: XAML CHƯƠNG II: XAML - Extensible Application Markup Language 1 Tổng quan về XAML 1.1 XAML là gì XAML được viết tắt bởi cụm từ: Extensible Application Markup Language là một ngơn ngữ dạng khai báo. Bạn cĩ thể tạo ra các phần tử đồ họa(UI) với những khai báo thơng qua thẻ trong XAML. Sau đĩ bạn cĩ thể dùng file mã lệnh tách biệt của nĩ(code-behind) để trả về những sự kiện và điều khiển những đối tượng mà bạn đã định nghĩa trong XAML. Nĩ là một ngơn ngữ mơ tả dựa trên XML là rất trực quan để xây dựng giao diện từ những bước phác thảo cho tới sản xuất sản phẩm, đặc biệt hữu ích cho đối tượng cĩ kinh nghiệm thiết kế website và kỹ thuật. 1.2 Khai báo đối tượng Cĩ hai cách để khai báo đối tượng trong XAML: 1.2.1 Khai bao trực tiếp: Sử dụng thẻ đĩng mở để khai báo một đối tượng giống như là một phần tử XML. Bạn cũng cĩ thể sử dụng cú pháp này để khai báo đối tượng gốc (root object) hoặc để xét các giá trị các thuộc tính. 1.2.2 Khai báo gián tiếp: Sử dụng giá trị trực tiếp để khai báo một đối tượng. Bạn cĩ thể sử dụng cú pháp này để thiết lập giá trị của thuộc tính.Thơng thường, điều này cĩ nghĩa là chỉ những thuộc tính mà được hỗ trợ bởi đối tượng mới cĩ thể sử dụng được phương pháp này. 1.3 Thiết lập đặc tính cho đối tượng Cĩ những cách sau để khai báo đặc tính cho đối tượng: 1.3.1 Sử dụng cú pháp theo thuộc tính Dưới đây là ví dụ xét giá trị cho các thuộc tính: Width, Height, Fill của đối tượng Rectangle: 1.3.2 Sử dụng cú pháp theo đặc tính của thành phần(element): Dưới đây là ví dụ xét đặc tính Fill theo cách này cho đối tượng Rectangle: Infoway Solutions CHƯƠNG II: XAML 2 1.3.3 Sử dụng cú pháp theo nội dung Dưới đây là ví dụ xét đặc tính Text cho đối tượng TextBlock(Giống như đối tượng Label trong Winform, Webform): Hello! 1.3.4 Sử dụng theo một tập hợp Đây là một trường hợp khá thú vị trong XAML, bởi cĩ những cách khác nhau để thể hiện tập hợp này. Hơn nữa nĩ cĩ thể xuất hiện ở phần đầu tiên của XAML cho phép bạn xét những đặc tính chỉ đọc (read-only) của đối tượng. Dưới đây là ví dụ xét đặc tính theo những cách khác nhau sử dụng theo kiểu tập hợp. Cách 1: Cách 2: <! —Khơng cần khai báo GradientStopCollection, bộ phân tích sẽ hiểu và tạo ra nĩ - -> Cách 3: Ngồi ra, cĩ những đặc tính mà chúng cĩ những tập hợp đặc tính nhưng chúng được xác định như là đặc tính nội dung của lớp. Trong trường hợp này ta xét đến đặc tính GradientStops được xử dụng ở trên. Bạn cĩ thể loại bỏ đặc tính này và sẽ cĩ kết quả như sau: 1.4 Root elements và namespace trong XAML Một file XAML chỉ được cĩ duy nhật một Root element và phải thỏa mãn cả hai tiêu chí sau: well- formed XML(cĩ mở và đĩng thẻ) và valid XML(tuân thủ theo Document Type Definition(DTD)). Ví dụ dưới đây cho Root element điển hình của XAML cho Silverlight với Root element là thành phần UserControl. <UserControl x:Class="MySilverlight.Page" xmlns="" xmlns:x="" > Infoway Solutions CHƯƠNG II: XAML 3 1.5 Sự kiện XAML là một ngơn ngữ khai báo cho đối tượng và những đặc tính của chúng, nhưng nĩ cũng bao gồm những cú pháp cho sự kết hợp sự kiện cho đối tượng trong những thẻ đánh dấu. Bạn chỉ rõ tên của sự kiện như là một thuộc tính tên trên đối tượng mà sự kiện được nghe. Về giá trị của thuộc tính, bạn chỉ rõ tên của hàm nghe sự kiện mà bạn định nghĩa ở phần code-behind hoặc ở phần javascript. Việc cĩ khai bao hay khơng đặc tính x:Class ở thẻ root trong XAML cĩ ảnh hưởng đến việc xử lý sự kiện. Nếu bạn khai báo x:Class tức là việc xử lý sự kiện của bạn sẽ được thực hiện trong code-behind, trường hợp này thường xuất hiện trong kiểu lập trình Managed API (chứa trong silverlight 2.0). Cịn ngược lại thì việc xử lý sự kiện của bạn được thực hiện ngay trong thẻ Javascript chứa trong HTML, trường hợp này thường xuất hiện trong kiểu lập trình JavaScript API (chứa trong Silverlight 1.0). - Ví dụ dưới đấy chỉ rõ cho bạn thấy cách tạo một sự kiện trong trường hợp kiểu lập trình Manged API <UserControl x:Class="Chapter2.Page" xmlns="" xmlns:x="" Width="400" Height="300"> Doạn mã trên, trong thẻ root chúng ta đã khai báo đặc tính x:Class=" Chapter2.Page", điều này cĩ nghĩa trong chương trình của chúng ta cĩ một file chứa class Chapter2.Page. Class này sẽ đảm nhiệm việc xử lý các sự kiện đã khai báo ở file XAML (Page.xaml). Trong thẻ chúng ta tạo thêm một nút và khai báo trong nút đĩ một sự kiện Click="Button_Click".Sự kiện này sẽ được xử lý ở trong code-behind như sau namespace Chapter2 { public partial class Page : UserControl { public Page() { InitializeComponent(); } private void Button_Click(object sender, RoutedEventArgs e) { //Xu ly su kien Button click o day MessageBox.Show("Xin chao!"); } } } - Cịn ví dụ dưới đây sẽ chỉ rõ cho bạn thấy cách tạo một sự kiện trong trường hợp kiểu lập trình JavaScript API <UserControl xmlns="" xmlns:x="" Width="400" Height="300"> Infoway Solutions CHƯƠNG II: XAML 4 Doạn mã trên, trong thẻ root chúng ta khơng khai báo đặc tính x:Class. Việc xử lý sự kiện sẽ được thực hiện ngay trong trang HTML cĩ chứa chương trình silverlight này. function Button_Click() { alert("Xin chao!"); } 2 Các namescope trong XAML Trong Silverlight, một XAML namescope lưu trữ quan hệ giữa những tên từ khĩa của XAML đã được định nghĩa của đối tượng và những khởi tạo tương đương của nĩ. Điều này cũng tương tự như ý nghĩa của “namescope” trong các ngơn ngữ lập trình và cơng nghệ khác. XAML namescope được tạo ra trong quá trình dịch mã XAML và trong quá trình tạo hình đối tượng. Những tên mà được tạo trong namescope sau đĩ được sử dụng ở code-behind thao tác lúc chạy chương trình để truy cập tới đối tượng được tạo bởi quá trình dịch file XAML. Để biết thêm chi tiết các bạn cĩ thể tham khảo tại địa chỉ: 3 Sử dụng XAMLReader.Load Sử dụng JavaScript API cho Silverlight, để tạo đối tượng trong lúc thực thi ứng dụng bắt buộc phải sử dụng qua phương thức CreateFromXaml. Sử dụng manged API những class hoặc cấu trúc (structure) cho phép cĩ thêm các thành phần bên trong thực sự được khởi tạo nếu nĩ cĩ trong cây thành phần của Silverlight. Trong hầu hết các trường hợp mà bạn muốn khởi tạo đối tượng trong lúc thực thi, bạn cĩ thể đơn giản triệu gọi constructor của class liên quan tới nĩ. Tuy vậy, Bạn vẫn cĩ thể tạo đối tượng thơng qua đầu vào là XAML thơng qua managed API, qua việc sử dụng phương thức XamlReader.Load. Phương thức Load trong managed API là tương ứng với CreateFromXaml trong JavaScript API, cũng giống như CreateFromXaml, đầu vào cho phương thức Load là những chuỗi và đầu ra là những đối tượng mà cĩ thể thêm vào mạng đối dạng cây của Silverlight. XamlReader đơn giản được thiết kể để đọc xml “XmlReader” cĩ trong Silverlight cũng như trong các cơng nghệ khác của Microsoft . XamlReader là lớp được xây dựng theo kiểu static với những phương thức tạo đối tượng; nĩ tạo đối tượng song song với việc xử lý XAML để sinh ra trong lúc thực thi(run- time) những cây đối tượng từ XAML trong Silverlight Các bạn cần lưu ý những điểm sau khi sử dụng phương thức Load: - Nội dung chuỗi XAML phải định nghĩa một phần tử gốc (root element) - Nội dung chuỗi XAML phải là well-formed XML, và valid XML 4 XAML và các Custom class Infoway Solutions CHƯƠNG II: XAML 5 XAML hỗ trợ khả năng cĩ thể định nghĩa tùy chỉnh lớp(custom class) hoặc cấu trúc(structure) trong bất kỳ ngơn ngữ runtime nào (CLR), và sau đĩ truy cập vào class thơng qua thẻ đánh dấu của XAML(XAML markup), bao gồm cách sử dụng hỗn hợp của những thẻ Silverlight đã định nghĩa trong XAML và những thẻ XAML mà tham chiếu tới custom class tương ứng của nĩ (Mỗi custom class chứa tương ứng 2 file .cs và .xaml, ví dụ: myclass.xaml và myclass.xaml.cs) 4.1 Custom class trong ứng dụng hoặc Assemblies Custom class dùng trong XAML cĩ thể định nghĩa theo cách riêng biệt: - Trong code-behind được đĩng gĩi trong ứng dụng Silverlight - Như là một class được định nghĩa trong một assembly tách biệt, như là một thư viện thực thi hoặc DLL Mỗi cách trên đều cĩ những ưu và nhược điểm như sau: - Ưu điểm của việc tạo class và đĩng gĩi riêng biệt là khả năng cĩ thể chia sẻ và dùng được trong nhiều ứng dụng Silverlight khác. Đồng thời là khả năng quản lý phiên bản của control dễ dàng hơn và nĩ làm cho nĩ cĩ khả năng tạo ra class mà bạn dự dịnh sử dụng như là một root element trong trang XAML. - Ưu điểm của việc tạo custom class trong ứng dụng là về mặt kỹ thuật tương đối đơn giản và giảm thiểu kích cỡ và kiểm tra khi bạn gặp vấn đề trong dự án Silverlight dựa trên code-behind. Tuy nhiên cĩ điểm hạn chế là bạn khơng thể dùng custom class như là một root element. Bạn phải tham chiếu custom class của bạn qua một assembly khác hoặc là giới hạn subclass sử dụng User Control hỗ trợ code-behind trong dự án Silverlight của bạn. - Dù là định nghĩa trong cùng một assembly hay assembly khác nhau, custom class phải được ánh xạ qua CLR namespace và XML namespace để được tham chiếu trong XAML 4.2 Ràng buộc để Custom Class trở thành thành phần đối tượng trong XAML Để được tạo đối tượng như là một thành phần đối tượng của XAML, custom class của bạn phải đáp ứng các yếu tố sau đây: - Custom class phải để public và hỗ trợ khởi tạo mặc định khơng cĩ tham số truyền vào (default constructure ‘parameterless’). - Custom class khơng phải là class lồng(class lồng và dấu chấm ‘.’ ở cú pháp của nĩ ảnh hưởng tới những đặc điểm của Silverlight như là các property kèm theo. Ngồi ra để đối tượng của bạn như là một thành phần đối tượng của XAML, bạn cĩ thể cho phép sử dụng những property cho các public property của Custom class của bạn điều này làm cho Custom class của bạn như là một kiểu property. Điều này bởi vì bây giờ đối tượng cĩ thể được khởi tạo giống như một thành phần đối tượng và cĩ thể xét thuộc tính cho nĩ như là một property 4.3 Yêu cầu đối với sự kiện trong XAML đối với Custom class Để sử dụng cú pháp theo kiểu thuộc tính để tương tác với sự kiện trong XAML, sự kiện phải được public trong class mà hỗ trợ constructure mặc định, hoặc sự kiện phải được định nghĩa trong class trừu tượng và sau đĩ sự kiện cĩ thể truy cập được qua những class kế thừa. Infoway Solutions CHƯƠNG II: XAML 6 5 XAML và Type Converter 6 Layout Khi bạn xây dựng ứng dụng Silverlight, một trong những điều bạn cần làm đầu tiên đĩ là việc sẽ bố trí giao diện đồ họa của bạn như thế nào. Silverlight cung cấp cho bạn 3 kiểu bố trí khác nhau, đĩ là: Canvas, StackPanel và Grid. 6.1 Canvas Định nghĩa một khu vực mà trong đĩ bạn cĩ thể chỉ ra vị trí của từng đối tượng thành phần bằng cách sử dụng các tọa độ tham chiếu. Bạn cĩ thể sử dụng lồng các Canvas với nhau và những thành phần bên trong của Canvas phải là một UIElement. Trong nhiều trường hợp thì Canvas chỉ đĩng vai trị như một đối tượng để chứa đựng những đối tượng khác và khơng cĩ một thuộc tính hiển thị nào. Một Canvas sẽ khơng được hiển thị nếu nĩ cĩ một trong những thuộc tính sau đây: - Thuộc tính Height xét giá trị 0 - Thuộc tính Width xét giá trị 0 - Background bằng null hoặc là Nothing ở VS Basic - Opacity xét giá trị 0 - Visibility bằng Visibility.Collapsed - Một trong những Canvas ở mức độ cao hơn (parrent) của nĩ khơng được hiển thị. Ví dụ dưới đây chỉ ra là hình chữ nhật được cách trái 30pixel và cách trên 30pixel <Rectangle Canvas.Left="30" Canvas.Top="30" Fill="red" Width="200" Height="200" /> 6.2 StackPanel Sắp xếp những thành phần bên trong nĩ thành một dịng và cĩ thể hiển thị theo hai kiểu ngang hoặc là dọc. Giá trị mặc định được gán chọ thuộc tính Orientation là chiều dọc (Vertical) và giá mặc định được xét cho hai thuộc tính HorizontalAlignment và VerticalAlignment là Stretch Ví dụ dưới đây hướng dẫn cách tạo những những đối tượng trong StackPanel Infoway Solutions CHƯƠNG II: XAML 7 6.3 Grid Định nghĩa dạng lưới phức tạp bao gồm những dịng và cột. Mặc định Grid chứa một cột và một dịng. Để định nghĩa nhiều cột hoặc dịng chúng ta dùng ColumnDefinitions và RowDefinitions. Mỗi ColumnDefinition và RowDefinition trong ColumnDefinitions và RowDefinitions xác định một dịng hoặc cột. ColumnDefinition và RowDefinition cũng định nghĩa kích thước của mỗi cột và dịng sử dụng đối tượng GridLength Ví dụ: Dưới đây là ví dụ dùng Grid để lên một thiết kế giao diện cơ bản. <Grid x:Name="LayoutRoot" Background="#DCDCDC" Width="400" Height="300" ShowGridLines="True"> <TextBlock Grid.Row="0" Grid.Column="0" Grid.ColumnSpan="2" Margin="10" FontWeight="Bold" Text="Contoso Corporation" HorizontalAlignment="Center" VerticalAlignment="Center" /> <Grid x:Name="FormLayoutGrid" Grid.Row="1" Grid.Column="0" ShowGridLines="True"> <TextBlock Grid.Row="0" Grid.Column="0" Text="First Name" Margin="10" HorizontalAlignment="Left" VerticalAlignment="Center" /> Infoway Solutions CHƯƠNG II: XAML 8 <TextBlock Grid.Row="1" Grid.Column="0" Text="Last Name" Margin="10" HorizontalAlignment="Left" VerticalAlignment="Center" /> <TextBlock Grid.Row="2" Grid.Column="0" Text="Address" Margin="10" HorizontalAlignment="Left" VerticalAlignment="Center" /> Thêm vào một vài đối tượng qua code-behind C# public Page() { InitializeComponent(); LayoutDesign(); } private void LayoutDesign() { //Tạo Stackpanel cho ListBox Control StackPanel DeptStackPanel = new StackPanel(); DeptStackPanel.Margin = new Thickness(10); LayoutRoot.Children.Add(DeptStackPanel); Grid.SetColumn(DeptStackPanel, 1); Grid.SetRow(DeptStackPanel, 1); TextBlock DeptListHeading = new TextBlock(); DeptListHeading.Text = "Department"; ListBox DeptList = new ListBox(); DeptList.Items.Add("Finance"); DeptList.Items.Add("Marketing"); DeptList.Items.Add("Human Resources"); DeptList.Items.Add("Payroll"); DeptStackPanel.Children.Add(DeptListHeading); DeptStackPanel.Children.Add(DeptList); //Tạo StackPanel cho các nút StackPanel ButtonsStackPanel = new StackPanel(); ButtonsStackPanel.Margin = new Thickness(10); ButtonsStackPanel.Orientation = Orientation.Horizontal; ButtonsStackPanel.HorizontalAlignment = HorizontalAlignment.Center; Infoway Solutions CHƯƠNG II: XAML 9 LayoutRoot.Children.Add(ButtonsStackPanel); Grid.SetColumn(ButtonsStackPanel, 0); Grid.SetRow(ButtonsStackPanel, 2); Grid.SetColumnSpan(ButtonsStackPanel, 2); Button BackButton = new Button(); BackButton.Content = "Back"; BackButton.Height = 30; BackButton.Width = 100; Button CancelButton = new Button(); CancelButton.Content = "Cancel"; CancelButton.Height = 30; CancelButton.Width = 100; Button NextButton = new Button(); NextButton.Content = "Next"; NextButton.Height = 30; NextButton.Width = 100; ButtonsStackPanel.Children.Add(BackButton); ButtonsStackPanel.Children.Add(CancelButton); ButtonsStackPanel.Children.Add(NextButton); BackButton.Margin = new Thickness(10); CancelButton.Margin = new Thickness(10); NextButton.Margin = new Thickness(10); } } Infoway Solutions CHƯƠNG II: XAML 10 Infoway Solutions CHƯƠNG III: SỬ DỤNG SILVERLIGHT TRÊN EXPRESSION BLEND VÀ VISUAL STUDIO 2008 CHƯƠNG III: SỬ DỤNG SILVERLIGHT TRÊN EXPRESSION BLEND VÀ VISUAL STUDIO 2008 1 Giới thiệu về các cơng cụ phát triển Expression Blend 2 kết hợp với VS2008 Expression Blen là một cơng cụ thiết kế chuyên nghiệp và đầy đủ tính năng để tạo các giao diện người dùng cho các ứng dụng trên nền tảng Microsoft Silverlight và Microsoft Window. Bằng việc tách rời mỗi tệp tin của dự án theo vai trị, Epxpression Blend cho phép nhà thiết kế chỉ cần tập trung vào việc sáng tạo cịn các lập trình viên thì tập trung vào cơng việc lập trình. Mỗi thành viên nhĩm cĩ thể làm việc mà khơng làm cản trở đến quá trình làm việc của người khác. Expression Blend cĩ thể làm ra các ứng dụng Windows Presentation Foundation(WPF), trang web Silverlight 1.0, User control cho Silverlight 2 (file .xap và các file hỗ trợ khác). Các thiết kế của bạn (visual design) được trình bày theo ngơn ngữ đánh dấu là XAML 1.1 Expression Blend làm việc như thế nào? Trong Expression Blen, Bạn cĩ thể thiết kế ứng dụng một cách trực quan, vẽ các hình, đường kẻ, và các Control cĩ trên Artboard, và sau đĩ bạn cĩ thể thay đổi sự xuất hiện và các hành động của chúng. Bạn cĩ thể nhập hình ảnd, video, và âm thanh. Cịn trong các ứng dụng trên nền tảng Window, bạn cịn cĩ thể nhập và thay đổi các đối tượng 3D. Bạn cĩ thể tạo các storyboard để làm chuyển động hình trong thiết kế của bạn, sau đĩ tùy trọn Trigger trong Storyboard khi người dụng cĩ tương tác với ứng dụng của bạn 1.2 Những tính năng cĩ được từ Expression Blend Expression Blend 2 bao gồm các tính năng sau: - Đầy đủ bộ các cơng cụ vẽ vector, nĩ bao gồm Text và các cơng cụ 3D - Dễ dàng sử dụng, giao diện trực quan hiện - Khả năng chuyển động thời gian thực - 3D and media support for enhancing user experiences - Hỗ trợ tăng cường cho người dùng nhiều kinh nghiệp với 3D và Media - Advanced, flexible, and reusable customization and skinning options for a variety of common controls - Nâng cao, linh động, tùy biến hĩa các tính năng sử dụng lại, các lựa chọn bề mặt cho một vào control phổ biến. - Tính năng tương tác mạnh mẽ với các nguồn dữ liệu và các tài nguyên bên ngồi - Tính năng thiết kế theo Real-time và markup views Infoway Solutions CHƯƠNG III: SỬ DỤNG SILVERLIGHT TRÊN EXPRESSION BLEND VÀ VISUAL STUDIO 2008 2 - Artwork import capabilities from Expression Design 2 - Khả năng nhập Artwork từ Expression Design 2 - Site import capabilities from Expression Encoder 2 - Khả năng nhập site từ Expression Encoder 2 - Tương tác với Visual Studio 2008 để giúp nhà thiết kế và lập trình viên làm việc chặt chẽ và hiệu quả với nhau 2 Bắt đầu nhanh với Silverlight 2 trên Expression Blend 2 2.1 Tạo một Project cho ứng dụng Silverlight 2 Bạn cĩ thể tạo một Project Silverlight 2 trong Microsoft Expression Blend 2 sau khi đã cài đặt Service Pack1 . với Expression Blend, một Project Silverlight sẽ xây dựng một ứng dụng Silverlight 2 với sự hỗ trợ các file bao gồm một trang HTML để kiểm tra cĩ tên là Default.html nĩ sẽ tải ứng dụng của bạn vào trình duyệt của window. Các bước tạo project cho silverlight 2 như sau 1. Trên thanh menu chọn File và chọn NewProject( CTRL+SHIFT+N) 2. Trong hộp hội thoại New Project , phí dưới chọn project type là Silverlight 2 Application 3. Đặt tên cho project của bạn, cái này sẽ trở thành tên thư mục và tên namespace của ứng dụng. Infoway Solutions CHƯƠNG III: SỬ DỤNG SILVERLIGHT TRÊN EXPRESSION BLEND VÀ VISUAL STUDIO 2008 3 4. Tiếp theo là chọn vị trí lưu trữ project trên ổ cứng của bạn bằng cách tìm trong nút “Browse”. 5. Trong mục Language, chọn ngơn ngữ là Visual C#, đĩ sẽ là ngơn ngữ để bạn viết trong file code-behind. 6. Chọn OK. Khi một project mới được tạo ra bạn cĩ thể bắt đầu ngay với các thao tác vẽ các khuơn hình và control trong trang chính(Page.xaml) Dưới đây là danh sách các file và các tham chiếu dll mà Expression Blend 2 tự tạo ra cho project mới của bạn 2.2. Vẽ khuơn hình (Shape) trên ứng dụng Silverlight 1. Trong hộp toolbox chọn một trong các cơng cụ shape sau: Hình chữ nhật hoặc hình Ellipse . 2. Trong khuơn vùng thiết kế, bạn cĩ thể kéo chiều rộng hoặc chiều dài hình chữ nhật này theo hướng di chuột. Infoway Solutions CHƯƠNG III: SỬ DỤNG SILVERLIGHT TRÊN EXPRESSION BLEND VÀ VISUAL STUDIO 2008 4 Mẹo: Nếu bạn giữ SHIFT khi kéo sẽ giữ được chiều rộng và chiều cao cùng kích thước. làm như vậy sẽ tạo ra một hình vuơng đối với hình chữ nhật, và hình trịn đối với hình ellipse Mẹo: Nếu bạn giữ ALT khi bạn vẽ mới một hình chữ nhật hoặc hình ellipse thì cơng cụ vẽ này sẽ tự động chọn điểm nhắp chuột ban đầu làm tâm để vẽ. 3. Lưu các thay đổi (CTRL+S) 2.3. Thiết kế Control trên ứng dụng Silverlight Các bước để thiết kế control 1. Trong hơpk Toolbox, chọn control là Textbox. 2. Trong khuơn vùng thiết kế, vẽ TextBox này bằng cách kéo thả chuột. đối tượng trả về sẽ là một TextBox mà bạn cĩ thể sửa nội dung chữ hiện thị trên TextBox đĩ ngay. Infoway Solutions CHƯƠNG III: SỬ DỤNG SILVERLIGHT TRÊN EXPRESSION BLEND VÀ VISUAL STUDIO 2008 5 • Bạn cĩ thể phĩng to, thu nhỏ, xoay, di chuyển và thực thi các sự kiện. 3. Lưu các thay đổi (CTRL+S). 3 Xây dựng chương trình Silverlight 2 với Expression Blend và Visual Studio 2008 Trong mục này chúng ta sẽ xây dựng một ứng dụng Silverlight 2 dùng để dự báo thời tiết tại cac vùng trên tồn thế giới. Chương trình ứng dụng này cĩ sự dụng kết hợp visual studio 2008 và Expression Blend Chúng ta sẽ xây dựng chương trình với kết quả là giao diện mơ tả dưới đây Trước tiên hãy xem qua cấu trúc ứng dụng trong Visual Studio 2008 sau khi đã tạo mới một Project Silverlight. Infoway Solutions CHƯƠNG III: SỬ DỤNG SILVERLIGHT TRÊN EXPRESSION BLEND VÀ VISUAL STUDIO 2008 6 Trong project WeatherWidget chúng ta cĩ một tham chiếu tới một Web service để triệu gọi dữ liệu dự báo thời tiết với liên kết Để kết nối tới một web service chúng ta cĩ thể xem thêm ở liên kết sau đây Bây giờ chúng ta sẽ sử dụng Expression Blend để thiết kế giao diện người dùng bằng cách chuột phải vào file Page.xaml chọn Open in Expression Blend Sau khi Expression Blend khởi động xong, các cấu trúc file và thư mục trên đĩ vẫn được sắp xếp và giữ nguyên giống như trong Visual Studio. Infoway Solutions CHƯƠNG III: SỬ DỤNG SILVERLIGHT TRÊN EXPRESSION BLEND VÀ VISUAL STUDIO 2008 7 Bây giờ chúng ta lần lượt tạo các Layout cho ứng dụng trên Expression Blend. Để thiết kế một lớp hình nền cho ứng dụng. Trên Toolbox, chuột phải chọn Canvas. Sau đĩ đặt tên cho Canvas này là LayoutRoot Với LayoutRoot ta chọn hình nền trong Resource đã được định nghĩa sẵn, chúng ta sẽ cĩ theo hình ảnh dưới đây Infoway Solutions CHƯƠNG III: SỬ DỤNG SILVERLIGHT TRÊN EXPRESSION BLEND VÀ VISUAL STUDIO 2008 8 Tiếp theo chúng ta lần lượt tạo thêm các Layout là các Canvas và StackPanel tương tự như với LayoutRoot để cĩ được các hình ảnh giao diện dưới đây Dưới đây là các đoạn mã Xaml tự sinh trong quá trình thiết kế với Expression Blend <Image x:Name="ConditionsOverlay" Margin="-13,-13,0,0" Source="{StaticResource SunBig}"/> <TextBlock Width="225" Height="37" TextAlignment="Right" FontSize="34" x:Name="TodayTemp" /> <TextBlock Width="225" Height="14" TextAlignment="Right" x:Name="TodayDescription" /> <TextBlock Width="225" Height="14" TextAlignment="Right" x:Name="TodayRange" /> <TextBlock Width="225" Height="14" TextAlignment="Right" x:Name="City" Text="ðang lấy dữ liệu..." /> <Canvas Width="71" Background="{StaticResource dividerVertical}" Margin="5, 0, 0, 0"> <TextBlock FontSize="11" x:Name="TomorrowName" Foreground="White" Opacity="0.5" /> Infoway Solutions CHƯƠNG III: SỬ DỤNG SILVERLIGHT TRÊN EXPRESSION BLEND VÀ VISUAL STUDIO 2008 9 <TextBlock Canvas.Top="35" x:Name="TomorrowLo" Foreground="White" Opacity="0.5" /> <Canvas Width="71" Background="{StaticResource dividerVertical}" Margin="5, 0, 0, 0"> <TextBlock FontSize="11" x:Name="DayAfterName" Foreground="White" Opacity="0.5" /> <TextBlock Canvas.Top="35" x:Name="DayAfterLo" Foreground="White" Opacity="0.5" /> <TextBlock FontSize="11" x:Name="TwoDaysAwayName" Foreground="White" Opacity="0.5" /> <TextBlock Canvas.Top="20" x:Name="TwoDaysAwayHi" Foreground="White" /> <TextBlock Canvas.Top="35" x:Name="TwoDaysAwayLo" Foreground="White" Opacity="0.5" /> <StackPanel Height="17" Background="{StaticResource dividerHorizontal}" Orientation="Horizontal" > <TextBlock Text="Làm tươi" Margin="5, 0, 5, 0" Width="105" Foreground="White" Opacity="0.5" MouseLeftButtonUp="TextBlock_MouseLeftButtonUp_Refresh" /> <TextBlock Text="Change ZIP" Margin="5, 0, 5, 0" Width="105" TextAlignment="Right" Foreground="White" Opacity="0.5" MouseLeftButtonUp="TextBlock_MouseLeftButtonUp_Zip" /> Để tạo sự kiện cho một Textblock trên Expression Blend. Sau khi chọn đúng đối tượng Texblock trên Objects and Timeline, nhắp đúp chuột vào vị trí tên sự kiện như hình vẽ dưới đây. Ngay lập tức Visual Studio sẽ mở ra cho chúng ta viết code behind. private void TextBlock_MouseLeftButtonUp_Zip(object sender, MouseButtonEventArgs e) { ZipCode.Text = ""; ZipCode.Foreground = new SolidColorBrush(Colors.Black); ConditionsScreen.Visibility = Visibility.Collapsed; ZipCodeScreen.Visibility = Visibility.Visible; } Bằng việc sự dụng kết hợp giữa Visual studio và Expression Blend, các sự cập nhật về mã lệnh cũng như các file trong ứng dụng luơn được thơng báo để 2 chương trình cùng cĩ được cập nhật mới nhất. Sau khi thiết kế đầy đủ các layout trên Expression Blend, việc cịn lại chủ yêu là dành cho người lập trình mã lệnh trên Visual Studio. Visual studio sẽ đĩng gĩi ứng dụng này thành file .xap (ở đây là WeatherWidget.xap). file này sẽ được triển khai ở bất kỳ một trang html hay aspx với dịng lệnh dưới đây. Infoway Solutions CHƯƠNG III: SỬ DỤNG SILVERLIGHT TRÊN EXPRESSION BLEND VÀ VISUAL STUDIO 2008 10 Trên trang HTML : <object data="data:application/x-silverlight-2," type="application/x- silverlight-2" width="100%" height="100%"> <a href="" style="text-decoration: none;"> <img src="" alt="Get Microsoft Silverlight" style="border-style: none"/> Trên trang ASPX : <asp:Silverlight ID="Xaml1" runat="server" Source="~/ClientBin/ WeatherWidget.xap" MinimumVersion="2.0.31005.0" Width="100%" Height="100%" /> Trên Visual studio bấm F5 để chạy ứng dụng ta sẽ cĩ kết quả dưới đây : Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 1 Giới thiệu về các control phổ biến của Silverlight SDK tích hợp trong VS2008 Các Control trong silverlight cho phép bạn lưu trữ nội dung hoặc các control khác, bạn cĩ thể tạo hoặc tự thiết kế được các control này để chúng hiển thị được những thay đổi trạng thái tới người dùng. Trong cơng cụ phát triển Visual studio 2008 đã tích hợp các cơng cụ silverlight (Cài đặt Siverlight tool, đã hướng dẫn ở chương một) cĩ rất nhiều các control cĩ sẵn để bạn tạo, thay đổi hoặc xử lý các sự kiện theo chúng Dưới đây là hình ảnh danh sách các cơng cụ đã cĩ trong Silverlight tool Ở Chương II chúng ta đã tìm hiểu về các cách trình bày control theo Layout (Grid, StackPanel, Canvas). Trong chương này chúng ta sẽ xem và tìm hiểu các control phổ biến trong silverlight 2 và cách trình bày chúng theo Layout đã học. 2 Các control phổ biến trong Silverlight 2 1.1 Border o Mổ tả Border cung cấp một background , khu vực cho phép bạn nhúng vào đĩ một thành phần duy nhất nhằm tạo ra hiệu quả về đồ hoạ. o Ví dụ Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 2 Text Surrounded by a Border 1.2 Button o Mơ tả Button kiểm sốt các phản ứng của người dùng qua các thiết bị đầu vào, bao gồm các sự kiện, style o Ví dụ <Button Name="Button" Content="Click Me !" Background="Blue" Margin="20,60,200,200" MouseLeftButtonDown="Button_MouseLeftButtonDown"/> 1.3 Calendar o Mơ tả Calendar cho phép người sử dụng chọn ngày, tháng, năm. Ta cĩ thể sử dụng các style khác nhau thơng qua Mode o Ví dụ 1.4 CheckBox o Mơ tả Cho phép người dùng lựa chọn ba trạng thái dánh dấu ,bỏ dánh dấu và trạng thái trung gian o Ví dụ <CheckBox Name="CheckBox1" ClickMode="Release" IsThreeState="False" Content="CheckBox two states" Margin="10,50,0,0"> Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 3 <CheckBox Name="CheckBox2" ClickMode="Release" IsThreeState="True" Content="CheckBox three states" Margin="10,100,0,0"> 1.5 ComboBox o Mơ tả ComboBox cho phép chọn lựa một Item từ một danh sách Item từ ComboBox o Ví dụ <ComboBox Name="ComboBox1" BorderThickness="2" IsDropDownOpen="True" SelectedIndex="0" Width="200" Height="30"> 1.6 ContentControl o Mơ tả ContentControl cĩ các dẫn xuất như Button, Panel. Ta cĩ thể tuỳ chỉnh ContentControl thơng qua các template o Ví dụ Sau đây là việc cài đặt một vài control được thừa kế từ ContentControl Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 4 \ 1.7 DatePicker o Mơ tả DatePicker cho phép người dùng sử dụng để lựa chọn ngày, hoặc gõ trực tiếp vào textbox hoặc sử dụng lịch thả xuống. DatePicker cung cấp một loạt các sự kiện hỗ trợ việc kiểm sốt lịch thả xuống. o Ví dụ <swc:Calendar x:Name="cal2" Canvas.Left="270" Canvas.Top="100" IsTodayHighlighted="false" /> <swc:DatePicker x:Name="dp2" Canvas.Left="20" Canvas.Top="480" SelectedDateFormat="Long"/> Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 5 1.8 GridSplitter o Mơ tả GridSplitter cho phép người dùng phân phối lại khơng gian giữa các hàng hoặc cột. Nĩ là yếu tố đồ hoạ tượng trưng cho một thành phần gắn vào nĩ mà thành phần đĩ cĩ thể tương tác o Ví dụ <swc:GridSplitter Grid.Row="1" Grid.Column="0" Grid.ColumnSpan="4" Height="5" HorizontalAlignment="Stretch" VerticalAlignment="Top" ShowsPreview="True" /> <swc:GridSplitter Grid.Row="2" Grid.Column="1" Grid.RowSpan="2" Width="5" HorizontalAlignment="Left" VerticalAlignment="Stretch" /> Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 6 1.9 HyperlinkButton o Mơ tả HyperlinkButton hiển thị một siêu liên kết. Khi bấm vào HyperlinkButton sẽ cho phép người dùng truy cập vào một trang web, địa chỉ URI đích được xác định với các NavigateUri. Bạn cĩ thể chỉ định cửa sổ hoặc một khung trong những điểm đến trang web bằng cách sử dụng TargetName o Ví dụ <TextBlock Text="HyperlinkButton Demonstration" Margin="0,20,10,20" FontFamily="Verdana" FontSize="18" FontWeight="Bold" Foreground="#FF5C9AC9" /> <HyperlinkButton Content="Click here to learn about Silverlight" NavigateUri="" TargetName="_blank" Margin="10,60,0,0"/> 1.10 Image o Mơ tả Image hiển thị hình ảnh trong định dạng JPEG hoặc PNG. Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 7 Hình ảnh hiển thị ở 1, 4 hoặc 8 bit màu, hình ảnh thực với 24 hoặc 32 bit o Ví dụ Mã XAML: Mã C#: Image myImage = new Image(); myImage.Source = new BitmapImage(new Uri("myPicture.jpg", UriKind.RelativeOrAbsolute)); LayoutRoot.Children.Add(myImage); 1.11 InkPresenter o Mơ tả InkPresenter cung cấp các bản vẽ mặt để hỗ trợ tính năng Tablet PC. InkPresenter được dẫn xuất từ canvas nên cĩ thể hiển thị một hoặc nhiều đối tượng và UIElement strokes. o Ví dụ Mã XAML: <InkPresenter x:Name="MyIP" Height="500" Width="500" Margin="50,50,0,0" MouseLeftButtonDown="MyIP_MouseLeftButtonDown" LostMouseCapture="MyIP_LostMouseCapture" MouseMove="MyIP_MouseMove" Background="Transparent" Opacity="1" /> Mã C# private void MyIP_MouseLeftButtonDown(object sender, MouseEventArgs e) { MyIP.CaptureMouse(); StylusPointCollection MyStylusPointCollection = new StylusPointCollection(); MyStylusPointCollection.Add(e.StylusDevice.GetStylusPoints(MyIP)); NewStroke = new Stroke(MyStylusPointCollection); MyIP.Strokes.Add(NewStroke); } //StylusPoint objects are collected from the MouseEventArgs and added to MyStroke. private void MyIP_MouseMove(object sender, MouseEventArgs e) { if (NewStroke != null) NewStroke.StylusPoints.Add(e.StylusDevice.GetStylusPoints(MyIP)); } //MyStroke is completed private void MyIP_LostMouseCapture(object sender, MouseEventArgs e) { NewStroke = null; } Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 8 1.12 ListBox o Mơ tả ListBox chứa một danh sách các Item, Item cĩ thể là một doạn văn bản hay một Control. o Ví dụ <TextBlock Text="ListBox Demonstration" Margin="0,20,10,20" FontFamily="Verdana" FontSize="18" FontWeight="Bold" Foreground="#FF5C9AC9" /> 1.13 MediaElement o Mơ tả Các MediaElement kiểm sốt nội dung Audio hoặc Video. Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 9 MediaElement cung cấp một vùng chữa nhật cĩ thể hiển thị Video trên đĩ, hoặc Audio o Ví dụ <MediaElement x:Name="media" Source="xbox.wmv" CurrentStateChanged="media_state_changed" Width="300" Height="300"/> 1.14 MultiScaleImage o Mơ tả MultiScaleImage cho phép người dùng mở một hình ảnh cho phép phĩng to thu nhỏ thơng qua cơng nghệ Deep Zoom. o Ví dụ Mã XAML: <MultiScaleImage x:Name="deepZoomObject" Source="source/items.bin" MouseEnter="DeepZoomObject_MouseEnter" /> Mã C#: private void DeepZoomObject_MouseEnter(object sender, MouseEventArgs e) { if (deepZoomObject.UseSprings = false) { deepZoomObject.UseSprings = true; } this.deepZoomObject.ZoomAboutLogicalPoint(3, .5, .5); } 1.15 PasswordBox o Mơ tả PasswordBox được sử dụng để nhập vào thơng tin mật khẩu ký tự hiển thị chỉ là ký tự đại diện. o Ví du Mã XAML: <PasswordBox x:Name="MyPWBox1" Margin="20,10,0,0" PasswordChanged="MyPWBox1_PasswordChanged" MaxLength="8" Height="35" Width="200" HorizontalAlignment="Left" /> Mã C#: public Page() { InitializeComponent(); } Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 10 private void MyPWBox1_PasswordChanged(object sender, RoutedEventArgs e) { ReadOnlyTB.Text = MyPWBox1.Password; } 1.16 Popup o Mơ tả Popup luơn luơn xuất hiện lên trên cùng cửa sổ ứng dụng hữu ích cho việc hiện thị thơng báo cho một nhiệm vụ o Ví dụ Mã XAML: <Button Width="100" Height="50" x:Name="showPopup" Click="showPopup_Click" Content="Show Popup" /> Mã C# // Create the popup object. Popup p = new Popup(); private void showPopup_Click(object sender, RoutedEventArgs e) { Border border = new Border(); border.BorderBrush = new SolidColorBrush(Colors.Black); border.BorderThickness = new Thickness(5.0); } 1.17 ProgressBar o Mơ tả ProgressBar hiển thị cho biết tiến trình đang hoạt động bằng việc thay đổi giá trị thay đổi. o Ví dụ Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 11 <TextBlock HorizontalAlignment="Center" Margin="10" Text="Value-Based Progress Bar" /> <ProgressBar x:Name="pg1" Value="100" Margin="10" Maximum="200" Height="15" IsIndeterminate="False" /> <TextBlock HorizontalAlignment="Center" Margin="10" Text="Indeterminate Progress Bar" /> <ProgressBar x:Name="pg2" Margin="10" Height="15" IsIndeterminate="True" /> 1.18 RadioButton o Mơ tả RadioButton cho phép người dùng chọn một tùy chọn từ một nhĩm các tùy chọn. Các RadioButton tổ chức trong cùng một nhĩm bằng cách đặt các GroupName chung cho mỗi RadioButton. Các RadioButton là một ContentControl o Ví dụ Mã XAML: <TextBlock Text="RadioButton Demonstration" Margin="0,20,10,20" FontFamily="Verdana" FontSize="18" FontWeight="Bold" Foreground="#FF5C9AC9" Grid.Row="0" Grid.ColumnSpan="2"/> <RadioButton x:Name="TopButton" Margin="5,0,0,0" Checked="HandleCheck" GroupName="First Group" Content="First Choice" Grid.Row="1" Grid.Column="1"/> <RadioButton x:Name="MiddleButton" Margin="5,0,0,0" Checked="HandleCheck" GroupName="First Group" Content="Second Choice" Grid.Row="3" Grid.Column="1"/> <RadioButton x:Name="LowerButton" Margin="5,0,0,0" Checked="HandleCheck" Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 12 Content="Third Choice" Grid.Row="4" Grid.Column="1"/> <TextBlock Grid.Row="5" x:Name="choiceTextBlock" Margin="0,10,0,0" Grid.ColumnSpan="2"/> Mã C#: private void HandleCheck(object sender, RoutedEventArgs e) { RadioButton rb = sender as RadioButton; choiceTextBlock.Text = "You chose: " + rb.GroupName + ": " + rb.Name; } 1.19 RepeatButton o Mơ tả RepeatButton là một nút kiểm sốt các sự kiện tác động vào nút như Mouse Click và thời gian giữa hai lần click liên tiếp o Ví dụ Mã XAML: RepeatButton Content="click and hold for multiple Click events" Click="RepeatButton_Click" Width="250" Margin="0,0,0,5" HorizontalAlignment="Left"/><TextBlock x:Name="clickTextBlock" Text="Number of Clicks:" /> Mã C#: static int Clicks = 0; private void RepeatButton_Click(object sender, RoutedEventArgs e) { Clicks += 1; clickTextBlock.Text = "Number of Clicks: " + Clicks; } Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 13 1.20 ScrollBar o Mơ tả ScrollBar cung cấp một thanh trượt cĩ khả năng di chuyển định hướng theo chiều ngang hoặc chiều dọc 1.21 ScrollViewer o Mơ tả ScrollViewer kiểm sốt một mảng content, cung cấp hai ScrollBar để kiểm sốt việc di chuyển mảng content . ScrollViewer cho phép bạn thiết lập kích cỡ của khoảng View liên quan đến Content theo chiều ngang và chiều dọc. o Ví dụ <ScrollViewer Height="200" Width="200" HorizontalScrollBarVisibility="Auto" Canvas.Top="60" Canvas.Left="340"> <TextBlock Width="300" TextWrapping="Wrap" Text="I am the very model of a modern Major-General,." /> 1.22 Slider o Mơ tả Slider cho phép người dùng lựa chọn từ một loạt các giá trị bằng cách di chuyển dọc theo một thanh ngang. o Ví dụ <Slider Margin="0,5,0,20" x:Name="slider1" Minimum="0" Maximum="10" /> Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 14 1.23 TabControl o Mơ tả TabControl cung cấp một giao diện hiển thị cho các thành phần. Các thành phần con của TabControl là các TabItem. o Ví dụ <UserControl xmlns:swc="clr- namespace:System.Windows.Controls;assembly=System.Windows.Controls" x:Class="TabControlExample.Page" xmlns="" xmlns:x="" FontFamily="Trebuchet MS" FontSize="11" Width="400" Height="300"> <swc:TabControl x:Name="tab1" Canvas.Top="20" Canvas.Left="20" Height="200" Width="300" /> <swc:TabControl x:Name="tab2" Canvas.Top="240" Canvas.Left="20" Height="200" Width="300" /> Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 15 1.24 TextBlock o Mơ tả TextBlock hiển thị nội dung văn bản. bạn cĩ thể gán các nội dung của một TextBlock bằng cách sử dụng nguồn text. Ngồi ra cũng cĩ thể gán TextBlock bằng một tập hợp các đối tượng text. o Ví dụ Hello, world! 1.25 TextBox o Mơ tả TextBox được sử dụng nhập dữ liệu dạng text từ người dùng hoặc hiển thị văn bản. TextBox thường được dùng để chỉnh sửa văn bản đơi khi cũng được dùng ở chế độ chỉ đọc. TextBox cĩ thể hiển thị nhiều dịng văn bản. o Ví dụ <TextBox x:Name="ReadWriteTB" TextChanged="ReadWriteTB_TextChanged" IsReadOnly="False" HorizontalAlignment="Left" Margin="20,5,0,0" Height="35" Width="200" /> 1.26 ToolTip o Mơ tả Tooltip cung cấp thơng tin về một đối tượng đồ họa bằng cách sử dụng một cửa sổ pupup. Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 16 o Ví dụ <TextBlock Text="TextBlock with an offset ToolTip." Canvas.Top="110" Canvas.Left="20" > <ToolTip Content="Offset ToolTip." HorizontalOffset="20" VerticalOffset="30"/> 1.27 DataGrid o Mơ tả DataGrid cung cấp một cách linh hoạt để hiển thị một tập hợp các dữ liệu trong các hàng và cột. Data Grid hỗ trợ nhiều style hiển thị dữ liệu trong các cột hoặc hàng. Data Grid hỗ trợ các bảng tùy chọn định dạng và khả năng hiển thị hoặc ẩn các tiêu đề, các thanh trượt di chuyển . Ngồi ra Data Grid cịn cung cấp một số kiểu mẫu mà bạn cĩ thể thay đổi hình thức thể hiện dữ liệu hàng, cột và tiêu đề. o Ví dụ <UserControl x:Class="DataGridSnippets.Page" xmlns="" xmlns:x="" xmlns:data="clr- namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data" Width="500" Height="Auto"> <TextBlock Text="DataGrid Demonstration" Margin="0,20,10,20" FontFamily="Verdana" FontSize="18" FontWeight="Bold" Foreground="#FF5C9AC9" /> <data:DataGrid x:Name="dataGrid1" Height="140" Margin="0,5,0,10" AutoGenerateColumns="True" /> <data:DataGrid x:Name="dataGrid3" Height="140" Margin="0,5,0,10" RowDetailsVisibilityMode="VisibleWhenSelected" > Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 17 <data:DataGrid x:Name="dataGrid4" Height="160" Margin="0,5,0,10" RowHeight="40" AutoGenerateColumns="False" > <data:DataGridTextColumn Header="First Name" Width="SizeToHeader" Binding="{Binding FirstName}" FontSize="20" /> <data:DataGridTextColumn Header="Last Name" Width="SizeToCells" Binding="{Binding LastName}" FontSize="20" /> <data:DataGridTextColumn Header="Address" Width="150" Binding="{Binding Address}" > <data:DataGridCheckBoxColumn Header="New?" Width="40" Binding="{Binding IsNew}" /> <data:DataGridCheckBoxColumn Header="Subscribed?" Width="Auto" Binding="{Binding IsSubscribed}" IsThreeState="True" /> <TextBlock Text="DataGrid with template column and custom alternating row backgrounds:"/> <data:DataGrid x:Name="dataGrid5" Height="125" Margin="0,5,0,10" AutoGenerateColumns="False" RowBackground="Azure" AlternatingRowBackground="LightSteelBlue"> <TextBlock Padding="5,0,5,0" Text="{Binding FirstName}"/> Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 18 <TextBox Padding="5,0,5,0" Text="{Binding FirstName}"/> <data:DataGridTextColumn Header="Address" Width="300" Binding="{Binding Address}" /> Mã C#: using System; using System.Collections.Generic; using System.Windows.Controls; namespace DataGridSnippets { public partial class Page : UserControl { public Page() { InitializeComponent(); // Thiết lập ItemsSource để tự tạo các cột. dataGrid1.ItemsSource = Customer.GetSampleCustomerList(); dataGrid3.ItemsSource = Customer.GetSampleCustomerList(); dataGrid4.ItemsSource = Customer.GetSampleCustomerList(); dataGrid5.ItemsSource = Customer.GetSampleCustomerList(); } } public class Customer { public String FirstName { get; set; } public String LastName { get; set; } public String Address { get; set; } public Boolean IsNew { get; set; } public Boolean? IsSubscribed { get; set; } public Customer(String firstName, String lastName, String address, Boolean isNew, Boolean? isSubscribed) { this.FirstName = firstName; this.LastName = lastName; this.Address = address; this.IsNew = isNew; this.IsSubscribed = isSubscribed; } public static List GetSampleCustomerList() { Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 19 return new List(new Customer[4] { new Customer("A.", "Zero", "12 North Third Street, Apartment 45", false, true), new Customer("B.", "One", "34 West Fifth Street, Apartment 67", false, false), new Customer("C.", "Two", "56 East Seventh Street, Apartment 89", true, null), new Customer("D.", "Three", "78 South Ninth Street, Apartment 10", true, true) }); } } } 3 User Control trong Visual Studio 2008 Trong ví dụ được trình bày dưới đây chúng ta tìm hiểu cách tạo một User Control và sử dụng nĩ như thế nào trong Visual Studio 2008 1. Trong Project Silverlight đã cĩ chúng ta làm thao tác tạo New Item theo hình vẽ dưới đây Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 20 2. Chọn Silverlight User Control trong Templates và đặt tên control này là FormContactUserControl.xaml 3. Chúng ta sẽ cĩ 2 file sau được tạo ra - FormContactUserControl.xaml - FormContactUserControl.xaml.cs Trong FormContactUserControl.xaml chúng ta sẽ cĩ đoạn mã sau <UserControl x:Class="Chapter2.FromContactUserControl" xmlns="" Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 21 xmlns:x="" > 4. Bây giờ chúng ta sẽ thêm đoạn mã dưới đây vào bên trong thẻ <Button x:Name="btnSubmit" Content="Lưu lại" Margin="140,150,0,0" Width="55" 5. Thêm sự kiện vào nut bấm “btnSubmit’. Chúng ta sẽ xử lý sự kiện btnSubmit_Click vào trong mã c# như sau private void btnSubmit_Click(object sender, RoutedEventArgs e) { // Phe duyet du lieu dau vao if (txtName.Text == "") { MessageBox.Show("Họ và tên khơng được bỏ trống"); txtName.Focus(); } else { //Tiep tuc xu ly luu contact //... } } 6. Làm thao tác Build Sulution, chúng ta đã tạo xong control FormContactUserControl. Bây giờ chúng ta mở file Page.xaml để sử dụng lại control đĩ. Chúng ta thêm mới đoạn mã sau: xmlns:inf="clr-namespace:Chapter2" vào bên trong thẻ Infoway Solutions CHƯƠNG IV: CONTROL VÀ USER CONTROL TRONG SILVERLIGHT 22 7. Để hiển thị được User control: FormContactUserControl trong Page.xaml ta tiếp tục thêm đoạn mã sau 8. Bấm F5 để chạy chương trình bạn sẽ được kết quả như hình ảnh sau 4 Các bài tập thực hành Các ví dụ, và các bài thực hành mở rộng các bạn cĩ thể tải về từ địa chỉ sau. liên kết này là các ví dụ bao gồm của chương 2 và chương 3 Infoway Solutons XỬ LÝ ĐỒ HỌA TRÊN SILVERLIGHT CHƯƠNG V: XỬ LÝ ĐỒ HỌA TRÊN SILVERLIGHT 1 Giới thiệu Silverlight cung cấp nhiều lựa chọn cho việc thêm các tính năng trực quan thú vị cho ứng dụng của bạn. Bạn cĩ thể sử dụng vẽ, Shape, Path, và những hình học phức tạp. Những khu vực được xác định bởi dạng hình thì cĩ thể tơ hiệu ứng, như là ảnh, dải màu, hoặc là đoạn video, thơng qua việc sử dụng Brush. Silverlight kế thừa mợt thư viện đồ họa khá đầy đủ từ WPF bởi vậy sẽ khơng quá khĩ khăn để một lập trình viên đã quen với WPF chuyển qua làm việc với Silverlight. Dưới đây chúng ta sẽ lần lượt làm quen với các đối tượng đồ họa như Ellipse, Line, Path, Polygon, Geometries, BrushesQ 2 Shapes and Drawing Trong Silverlight, Shape là kiểu UIElement nên bạn cĩ thể dễ dàng hiển thị một đối tượng dạng Shape lên màn hình. Bởi vì chúng là những thành phần đồ họa nên những đối tượng Shape này cĩ thể đi kèm với những container như Grid và Canvas. Silverlight cung cấp những dạng hình(Shape) mà bạn cĩ thể dùng ngay được như Ellipse, Line, Path, Polygon, Polyline, và Rectangle. Những Shape đều cĩ chung những đặc tính dưới đây: - Stroke: dùng để vẽ viền ngồi của Shape. - StrokeThickness: độ dày của viền ngồi của Shape. - Fill: Mơ tả cách phía bên trong của Shape được vẽ. - Đặc tính Data chỉ rõ tọa độ và các đỉnh được định nghĩa tùy theo thơng tin đầu vào Những đối tượng Shape cĩ thể dùng bên trong Canvas. Canvas hỗ trợ chỉ ra vị trí tuyệt đối của đối tượng con bên trong thơng qua đặc tính đính kèm là Canvas.Left và Canvas.Top 2.1 Ellipse Bạn cĩ thể tạo một Ellipse bằng cách xác định hai thuộc tính cơ bản là rộng(Width) và cao(Height) như ví dụ minh họa dưới đây. <Ellipse Fill="Yellow" Height="100" Width="200" StrokeThickness="2" Stroke="Black"/> Infoway Solutons XỬ LÝ ĐỒ HỌA TRÊN SILVERLIGHT 2.2 Line Cho phép bạn vẽ một đoạn thẳng giữa hai điểm. Ví dụ dưới đây chỉ ra một số cách để bạn xác định tọa độ của đoạn thẳng và đặc tính Stroke của nĩ. <!—Vẽ một đường chéo từ tọa độ (0, 0) tới (100,100) và di chuyển nĩ tới gốc tọa độ mới thêm 100 pixels về phía bên phải. --> <RadialGradientBrush GradientOrigin="0.5,0.5" Center="0.5,0.5" RadiusX="0.5" RadiusY="0.5"> 2.3 Path Lớp Path cho phép bạn vẽ những hình cong và những dạng hình phức tạp. Những hình cong và dạng hinh(shape) được diễn tả thơng qua việc sử dụng đối tượng Geometry. Để sử dụng Path, bạn tạo một Geometry và dùng nĩ để xét cho đặc tính Data của đối tượng Path. Cĩ nhiều loại đối tượng Geometry khác nhau để bạn chọn: LineGeometry, RectangleGeometry, và EllipseGeometry cĩ liên quan tới những dạng hình(shape) đơn giản lần lượt tương ứng Line, Rectangle, Ellipse. Để tạo những dạng hình phức tạp hoặc hình trịn chúng ta sử dụng PathGeometry. Ví dụ dưới đây xử dụng cú pháp rút gọn để biểu diễn một dạng hình phức tạp. <Path Stroke="DarkGoldenRod" StrokeThickness="3" Data="M 100,200 C 100,25 400,350 400,175 H 280" /> Infoway Solutons XỬ LÝ ĐỒ HỌA TRÊN SILVERLIGHT 2.4 Polygon Để xác định một đa giác(Polygon) bạn cần cung cấp một danh sách các điểm (Point) và tơ màu cho nĩ qua đặc tính Fill. Ví dụ dưới đây vẽ một đa giác với màu viền đỏ tía và bên trong được đổ màu xanh. <Polygon Points="300,200 400,125 400,275 300,200" Stroke="Purple" StrokeThickness="2"> 2.5 Polyline Cũng tương tự như đối tượng Polygon ngoại trừ việc khơng nhất thiết Polyline phải khép kín. Bạn cũng cĩ thể nhận được kết quả tương tự như Polyline khi vẻ chồng lên nhau nhiều Line. Chú ý Polyline với một điểm(Point) sẽ khơng được hiển thị lên. Ví dụ dưới đây vẽ một Polyline là một hình tam giác viền màu xanh khép kín. <Polyline Points="50,25 0,100 100,100 50,25" Stroke="Blue" StrokeThickness="10" Canvas.Left="75" Canvas.Top="50" /> 2.6 Rectangle Một hình chữ nhật(Rectangle) được xác định bởi hai đặc tính rộng(Width) và cao(Height), để xác định vị trí của Rectangle trong container chúng ta sử dụng thuộc tính Margin hoặc Canvas.Left, Canvas.Top để tùy chỉnh. Rectangle khơng hỗ trợ đối tượng con bên trong bởi vậy nếu bạn muốn khu vực Rectangle chứa những đối tượng Infoway Solutons XỬ LÝ ĐỒ HỌA TRÊN SILVERLIGHT khác bạn cĩ thể sử dụng Canvas. Bạn cũng cĩ thể dùng dạng hình hỗn hợp, nhưng trong trường hợp này cĩ lẽ bạn nên sử dụng RectangleGeometry hơn là việc dùng Rectangle. Ví dụ dưới đây hiển thị một Rectangle viền màu đỏ và tơ màu bên trong màu xanh. <Rectangle Width="100" Height="100" Fill="Blue" Stroke="Red" Canvas.Top="20" Canvas.Left="20" StrokeThickness="3" /> 3 Geometries Cung cấp lớp cơ sở cho những đối tượng để xác định dạng hình học cho đối tượng. Đối tượng Geometry cĩ thể sử dụng để làm vùng giao(clipping regions) và cũng như định nghĩa dữ liệu cho đối tượng Path. 3.1 EllipseGeometry Miêu tả hình dạng của đường trịn hoặc ellipse. FillRule là đặc tính kế thừa từ lớp cơ sở Geometry nhưng tùy chọn này khơng cĩ tác dụng đối với EllipseGeometry. EllipseGeometry chỉ đơn giản định nghĩa hình dạng cho ellipse và khơng thể tự nĩ hiển thị được. Bởi vì nĩ rất đơn giản và phạm vi sử dụng rộng. Ví dụ dưới đây vẽ một path sử dụng dữ liệu dạng EllipseGeometry 3.2 PathGeometry Miêu tả dạng hình phức tạp cĩ thể gồm cĩ hình cung, đường cong, ellipse, đoạn thẳng, và hình chữ nhật. Mỗi PathGeometry xác định bởi một danh sách đối tượng PathFigure. Mỗi đối tượng PathFigure bao gồm một hoặc nhiều PathSegment, tương tự cũng như với ArcSegment và LineSegment. Để phủ kín diện tích của PathGeometry thì mọi đối Infoway Solutons XỬ LÝ ĐỒ HỌA TRÊN SILVERLIGHT tượng PathFigure bạn phải xét thuộc tính IsFilled là "true" và FillRule để xác định khu vực được fill. 3.3 GeometryGroup Miêu tả một hỗn hợp hình dạng, được tạo thành từ nhiều đối tượng Geometry khác. Sử dụng FillRule cho GeometryGroup là rất hợp lý bởi sự kết hợp các hình dạng cĩ thể cĩ khả năng kết hợp các đoạn nơi mà sự áp dụng của quy luật fill cĩ tác dụng. 4 Brushes Bạn cĩ thể tơ màu các đối tượng trong Silverlight với màu đơn, dải nghiêng, bán kính nghiêng và ảnh. Infoway Solutons XỬ LÝ ĐỒ HỌA TRÊN SILVERLIGHT 4.1 Solid Color Một trong những thao tác chung trong bất cứ nền tảng nào là tơ màu một khu vực với một màu đơn sắc. Để thực hiện việc này, Silverlight cung cấp lớp SolidColorBrush. Dưới đây chúng tơi sẽ chỉ ra những cách khác nhau để tơ màu với SolidColorBrush. Để tơ màu một khu vực với màu đơn trong XAML, sử dụng theo những tùy chọn sau: o SolidColorBrush được định nghĩa trước theo tên. Ví dụ dưới đây dùng SolidColorBrush để xét thuộc tính Fill của hình chữ nhật(Rectangle). o Chọn từ bảng màu 32-bit với định dạng #rrggbb với rr, gg, bb lần lượt là 2 số mã 16 cho các màu đỏ, xanh lá, xanh lơ. Mở rộng thêm bạn cĩ thể xét với định dạng như sau: #aarrggbb với r, g, b ý nghĩa như trên và aa ở đây chỉ giá trị alpha hoặc là độ trong suốt. o Sử dụng thuộc tính kiểu phần tử để mơ tả SolidColorBrush( ở đây là thuộc tính Fill) 4.2 Gradient Gradient brush vẽ một khu vực với nhiều màu sắc pha trộn vào nhau dọc theo một trục. Bạn cĩ thể sử dụng chúng để tạo ra hiệu ứng ánh sáng và bĩng, mang lại cho thành phần đồ họa của bạn cảm giác 3 chiều. Bạn cũng cĩ thể sử dụng chúng để mơ phỏng kính, chrome, nước, và các bề mặt mịn. Silverlight cung cấp 2 loại gradient brush là : LinearGradientBrush và RadialGradientBrush. a. Linear Gradients LinearGradientBrush dùng để vẽ một khu vực với một dải nghiêng. Bạn chỉ ra màu sắc cho dải nghiêng và vị trí dọc theo trục nghiêng thơng qua việc sử dụng đối tượng GradientStop. Bạn cũng cĩ thể chỉnh sửa trục nghiêng, nĩ cho phép bạn tạo dải nghiêng theo chiều dọc hoặc ngang và đảo hướng của Infoway Solutons XỬ LÝ ĐỒ HỌA TRÊN SILVERLIGHT dài nghiêng. Ví dụ dưới đây sử dụng dải nghiêng với 4 màu và sử sụng nĩ để vẽ lên hình chữ nhật. b. Radial Gradients Giống như LinearGradientBrush, một RadialGradientBrush vẽ một khu vực với màu sắc mà pha trộn với nhau dọc theo một trục. Cách vẽ của RadialGradientBrush dựa theo một trục được xác định bởi đường trịn; màu sắc của nĩ tia ra ngồi từ phía gốc của nĩ. Ví dụ dưới đây vẽ một hình chữ nhật sử dụng RadialGradientBrush để tơ màu bên trong. <RadialGradientBrush GradientOrigin="0.5,0.5" Center="0.5,0.5" RadiusX="0.5" RadiusY="0.5"> Infoway Solutons XỬ LÝ ĐỒ HỌA TRÊN SILVERLIGHT Dưới đây là một vài tùy chọn khác nhau giúp bạn tạo một số kiểu hiệu ứng khác nhau với RadialGradientBrush: 4.3 Images Lớp ImageBrush cho phép bạn sử dụng ảnh để fill, để xét làm bacrkground, và viền ngồi. ImageBrush sử dụng được với những định dạng ảnh JPEG hoặc PNG và được dùng thơng qua thuộc tính ImageSource. Bạn cĩ thể cung cấp thơng tin ImageSource với đường dẫn của ảnh để tải chúng. Infoway Solutons XỬ LÝ ĐỒ HỌA TRÊN SILVERLIGHT Mặc định ImageBrush sẽ giãn ảnh ra hết tồn bộ khu vực được vẽ, cĩ thẻ ảnh sẽ bị làm méo nếu khu vực được vẽ cĩ tỉ lệ bề mặt khác với ảnh. Bạn cĩ thể thay đổi trạng thái này bằng việc thay đổi thuộc tính Stretch mặc định của nĩ tới một trong những giá trị sau: None, Uniform, UniformToFill. Ví dụ dưới đây sử dụng ImageBrush để vẽ nền của một Canvas 4.4 Video VideoBrush cho phép bạn vẽ một khu vực bằng video. Ví dụ dưới đây sử dụng VideoBrush để vẽ màu chữ(Foreground) của TextBlock <MediaElement x:Name="butterflyMediaElement" Source="Butterfly.wmv" IsMuted="True" Opacity="0.0" IsHitTestVisible="False" /> <TextBlock Canvas.Left="5" Canvas.Top="30" FontFamily="Verdana" FontSize="120" FontWeight="Bold" TextWrapping="Wrap" Text="Video"> Infoway Solutons XỬ LÝ ĐỒ HỌA TRÊN SILVERLIGHT 4.5 Deep Zoom Deep Zoom cung cấp khả năng phĩng to thu nhỏ một cách tùy ý những ảnh lớn trong Siliverlight một cách hiệu quả nhất. Ảnh cĩ thể hiển thị ở mức rất nhỏ và rất lớn mà khơng ảnh hưởng tới hiệu quả hoạt động của ứng dụng đang hiển thị ảnh. Chỉ cĩ thuộc tính làm ảnh hưởng tới hiệu quả hoạt động đĩ là độ phân giải của màn hình. Để biết thêm chi tiết mời các bạn tham khảo địa chỉ sau: us/library/cc645050(VS.95).aspx Infoway Solutions CHƯƠNG VI: MEDIA VÀ ANIMATION CHƯƠNG VI: MEDIA VÀ ANIMATION 1 Animation Animation là một ảo giác được tạo ra bằng cách thay đổi một loạt các hình ảnh. Não nhận các hình ảnh như là một thay đổi cảnh. Trong phim ảo giác này được tạo bằng cách sử dụng các camera cĩ ghi lại rất nhiều hình ảnh, khi hình ảnh được phát trở lại bằng một máy chiếu, các khán giả thấy một hình ảnh chuyển động. Silverlight cĩ chứa rất nhiều các đối tượng cĩ thể thực hiện được việc tạo ra ảo giác chuyển động. 1.1 Storyboard Kiểm sốt các animation với một timeline và cung cấp các đối tượng và tài nguyên nhằm mục đích cung cấp thơng tin cho các animation con <PointAnimation Storyboard.TargetProperty="Center" Storyboard.TargetName="MyAnimatedEllipseGeometry" Duration="0:0:5" From="20,200" To="400,100" RepeatBehavior="Forever" /> <EllipseGeometry x:Name="MyAnimatedEllipseGeometry" Center="20,20" RadiusX="15" RadiusY="15" /> <Button Click="Animation_Begin" Width="65" Height="30" Margin="2" Content="Begin" /> <Button Click="Animation_Pause" Width="65" Height="30" Margin="2" Content="Pause" /> <Button Click="Animation_Resume" Width="65" Height="30" Margin="2" Content="Resume" /> Infoway Solutions CHƯƠNG VI: MEDIA VÀ ANIMATION <!-- Button that stops Animation. Stopping the animation returns the ellipse to its original location. --> <Button Click="Animation_Stop" Width="65" Height="30" Margin="2" Content="Stop" /> private void Animation_Begin(object sender, RoutedEventArgs e) { myStoryboard.Begin(); } private void Animation_Pause(object sender, RoutedEventArgs e) { myStoryboard.Pause(); } private void Animation_Resume(object sender, RoutedEventArgs e) { myStoryboard.Resume(); } private void Animation_Stop(object sender, RoutedEventArgs e) { myStoryboard.Stop(); } 1.2 Key-Frame Animations Key-frame animations cho phép bạn tương tác vào animation nhiều hơn hai đối tượng và kiểm sốt một animation bằng phương pháp nội suy. Key-frame ko cĩ các thuộc tính như From / To / bởi Animation. Bạn tạo ra key-frame, các đối tượng animation được key-frame kiểm sốt, khi các hình ảnh động chạy nĩ sẽ chuyển giữa các frame mà bạn xác định tạo ra một chuỗi chuyển động liền mạch <!-- Animate the TranslateTransform's X property from 0 to 350, then 50, then 200 over 10 seconds. --> <DoubleAnimationUsingKeyFrames Storyboard.TargetName="MyAnimatedTranslateTransform" Infoway Solutions CHƯƠNG VI: MEDIA VÀ ANIMATION Storyboard.TargetProperty="X" Duration="0:0:10"> <!-- Using a LinearDoubleKeyFrame, the rectangle moves steadily from its starting position to 500 over the first 3 seconds. --> <!-- Using a DiscreteDoubleKeyFrame, the rectangle suddenly appears at 400 after the fourth second of the animation. --> <!-- Using a SplineDoubleKeyFrame, the rectangle moves back to its starting point. The animation starts out slowly at first and then speeds up. This KeyFrame ends after the 6th second. --> <SplineDoubleKeyFrame KeySpline="0.6,0.0 0.9,0.00" Value="0" KeyTime="0:0:6" /> <Rectangle MouseLeftButtonDown="Mouse_Clicked" Fill="Blue" Width="50" Height="50"> <TranslateTransform x:Name="MyAnimatedTranslateTransform" X="0" Y="0" /> // When the user clicks the Rectangle, the animation // begins. private void Mouse_Clicked(object sender, MouseEventArgs e) { myStoryboard.Begin(); } ubleanimationusingkeyframes/ClientBin/TestPage.html 1.3 Double Animation Double Animation biến đổi giá trị giữa hai biến của đối tượng Animation bằng cách sử dụng nội suy tuyến tính trên một khoảng thời gian xác định <DoubleAnimation Infoway Solutions CHƯƠNG VI: MEDIA VÀ ANIMATION Storyboard.TargetName="MyAnimatedRectangle" Storyboard.TargetProperty="Opacity" From="1.0" To="0.0" Duration="0:0:5" AutoReverse="True" RepeatBehavior="Forever" /> <Rectangle Loaded="Start_Animation" x:Name="MyAnimatedRectangle" Width="100" Height="100" Fill="Blue" /> private void Start_Animation(object sender, EventArgs e) { myStoryboard.Begin(); } ubleanimation/ClientBin/TestPage.html 1.4 Color Animation Color Animation biến đổi màu giữa hai biến của đối tượng Animation bằng cách sử dụng nội suy tuyến tính trên một khoảng thời gian xác định <StackPanel x:Name="myStackPanel" Background="Red" Loaded="Start_Animation"> <!-- Animate the background color of the canvas from red to green over 4 seconds. --> <ColorAnimation BeginTime="00:00:00" Storyboard.TargetName="myStackPanel" Storyboard.TargetProperty="(Panel.Background).(SolidColorBrush.Color)" From="Red" To="Green" Duration="0:0:4" /> private void Start_Animation(object sender, EventArgs e) { colorStoryboard.Begin(); } TestPage.html 1.5 Point Animation Point Animation biến đổi giá trị toạ độ của một điểm giữa hai biến của đối tượng Animation bằng cách sử dụng nội suy tuyến tính trên một khoảng thời gian xác định Infoway Solutions CHƯƠNG VI: MEDIA VÀ ANIMATION <!-- Animate the center point of the ellipse from 100 X, 300 Y to 400 X, 100 Y over 5 seconds. --> <PointAnimation Storyboard.TargetProperty="Center" Storyboard.TargetName="MyAnimatedEllipseGeometry" Duration="0:0:5" From="100,300" To="400,100" RepeatBehavior="Forever" /> <EllipseGeometry x:Name="MyAnimatedEllipseGeometry" Center="200,100" RadiusX="15" RadiusY="15" /> // Start the animation when the object loads private void Start_Animation(object sender, EventArgs e) { myStoryboard.Begin(); } /TestPage.html 2 Media Các tính năng đa phương tiện của Silverlight và mơ tả cách tích hợp audio và video vào trang Silverlight 2.1 MediaElement Object Để them media(video, audio) vào trang web của bạn ta sử dụng MediaElement . MediaElement sẽ cung cấp cho bạn một Form để hiển thị media , bạn chỉ cần cung cấp các Infoway Solutions CHƯƠNG VI: MEDIA VÀ ANIMATION nguồn tài nguyên media cho URI, như là một file video chẳng hạn. Các MediaElement bắt đầu play khi trang web của bạn tải về. <MediaElement x:Name="media" Source="xbox.wmv" Width="300" Height="300" /> erview_snip/js/media_simple.html 2.2 Controlling Media Playback Interactively Bạn cĩ thể tương tác điều khiển media bằng cách sử dụng Play, Pause, Stop, và các thuộc tính của một đối tượng MediaElement. Ví dụ như định nghĩa một đối tượng MediaElement với một số nút điều khiển cho các file (video, audio) phát. <MediaElement x:Name="media" Source="xbox.wmv" Width="300" Height="300" Grid.Column="0" Grid.Row="0" Grid.ColumnSpan="3" /> <Button Click="StopMedia" Grid.Column="0" Grid.Row="1" Content="Stop" /> <Button Click="PauseMedia" Grid.Column="1" Grid.Row="1" Content="Pause" /> <Button Click="PlayMedia" Grid.Column="2" Grid.Row="1" Content="Play" /> private void StopMedia(object sender, RoutedEventArgs e) { media.Stop(); } private void PauseMedia(object sender, RoutedEventArgs e) { media.Pause(); } private void PlayMedia(object sender, RoutedEventArgs e) { media.Play(); Infoway Solutions CHƯƠNG VI: MEDIA VÀ ANIMATION } vw_controlling_media/ClientBin/TestPage.html 2.3 Timeline Markers Một timeline marker là siêu dữ liệu liên kết với một điểm trong một tập tin media. các đánh dấu thường được tạo trước và được lưu trữ trong các tập tin media riêng. chúng thường được sử dụng để đặt tên khác nhau trong một cảnh quay video, cho phép người sử dụng tìm đến một vị trí hoặc cung cấp các phân cảnh. Khi MediaElement đạt đến một thời gian đánh dấu trong quá trình phát, nĩ sẽ tăng MarkerReached, sự kiện này cĩ thể sử dụng để kích hoạt hành động khác. Một MediaElement của đối tượng Marker đều cho phép bạn truy cập vào tiêu đề (nhúng, đánh dấu lưu trữ trong tập tin media). Một tập tin cĩ thể chứa cả hai bao gồm tiêu đề nhúng tập lệnh và tập lệnh riêng biệt <TextBlock FontSize="12" Foreground="DarkGray">Time: <TextBlock FontSize="12" Foreground="DarkGray">Type: <TextBlock FontSize="12" Foreground="DarkGray">Value: <MediaElement MarkerReached="OnMarkerReached" HorizontalAlignment="Left" Source="thebutterflyandthebear.wmv" Width="300" Height="200" /> private void OnMarkerReached(object sender, TimelineMarkerRoutedEventArgs e) { timeTextBlock.Text = e.Marker.Time.Seconds.ToString(); typeTextBlock.Text = e.Marker.Type.ToString(); valueTextBlock.Text = e.Marker.Text.ToString(); } Infoway Solutions CHƯƠNG VI: MEDIA VÀ ANIMATION 2.4 Server-Side Playlist Một server-side playlist là một dãy các tài nguyên media cho phép quản trị viên trên máy chủ kiểm sốt các tài nguyên media của người sử dụng. một danh sách media phía máy chủ được sử dụng để phục vụ việc phát media, nĩ cĩ thể ko khơng cho phép download từ client. Silverlight sử dụng tập tin wsx để cấu hình xác định một server-side playlist(SSPL) cĩ thể được phục vụ cho client thơng qua các đối tượng MediaElement. Một số lợi ích của việc sử dụng (SSPL) như sau - Giảm băng thơng do giảm số lần phía client kết nối tới server để lấy nội dung. - Bạn cĩ thể tuỳ chọn danh sách media khi mà bạn đang phát một danh sách media từ trước. - Bạn cĩ thể kiểm sốt, bổ sung media. Ví dụ bạn cĩ thể chơi chỉ một phần của một tập tin media. Infoway Solutions CHƯƠNG VII: LÀM VIỆC VỚI DỮ LIỆU TRONG SILVERLIGHT CHƯƠNG VII: LÀM VIỆC VỚI DỮ LIỆU TRONG SILVERLIGHT 1 Các cơng nghệ để truy cập dữ liệu trong Silverlight Trong các ứng dụng trên nền tảng Silverlight 2 cĩ cho phép truy cập dữ liệu theo nhiều cơng nghệ hay phương thức khác nhau. Cách đơn giản nhất để hiển thị và tương tác người dùng là Data Binding. Cách khác nữa để truy cập dữ liệu từ ứng dụng máy khách, như là một sự thay thế tối ưu của cookie, chúng ta cĩ thể sử dụng cơng nghệ Isolated Storage. Silverlight cũng cho phép đọc và ghi trên dữ liệu XML bằng cách sử dụng XmlReader hoặc LINQ to XML . Ngồi ra cách phổ biến trong các ứng dụng hiện nay thường làm đĩ là truy cập dữ liệu SQL Server thơng qua các cơng nghệ Web service, WCF và ADO.Net Data Service. Trong chương này chúng ta sẽ tìm hiểu một số cơng nghệ để truy cập dữ liệu sau: - Data Binding - Isolated Storage - Xử lý dữ liệu XML với LINQ to XML - Truy cập cơ sở dữ liệu SQL Server với Web Service(WCF) 2 Sử dụng Data Binding Data Binding cung cấp một cách đơn giảm cho ứng dụng nền tảng silverlight truy cập và tương tác tới dữ liệu. Thơng thường Data Binding quản lý dữ liệu theo luồng giữa người dùng và các đối tượng dữ liệu. Tức kà khi một binding được tạo và dữ liệu cĩ thay đổi, thì giao diện người dùng cũng được trình bày và thay đổi theo dữ liệu(tự động ánh xạ ). Tương tự khi người dùng thay đổi trên giao diện thì nĩ cũng cĩ thể làm thay đổi đối tượng dữ liệu. Ví dụ như khi người dùng thay đổi giá trị trên một TextBox, giá trị dữ liệu cũng tự động cập nhật theo thay đổi đĩ. o Sự liên kết giữa giao diện người dùng và dữ liệu - Binding Object: Như là một xúc tác ở giữaBindingTarget và Binding Source - Binding Source: Chứa các thuộc tính dữ liệu, cịn cĩ thể là đối tượng của CLR - Binding Target: Là các thuộc tính giao diệu người dùng để cĩ thể hiển thị hoặc thay đổi tới dữ liệu. Binding target cĩ thể là DependencyProperty của FramworkElement Infoway Solutions CHƯƠNG VII: LÀM VIỆC VỚI DỮ LIỆU TRONG SILVERLIGHT 2 - Value Converter: Thành phần tùy chọn để áp dụng cho những trường hợp dữ liệu cần phân tích hoặc chuyển đổi - Điều hướng của luồng dữ liệu: Quyết định tới việc tương tác dữ liệu qua lại giữa Binding Source và Binding Target (xem chi tiết mục dưới) Ví dụ dưới đây sẽ chỉ rõ cách trình bày thuộc tính màu của chữ (ForeGround Color) của một TextBox: Mã XAML: <TextBox x:Name="MyTextBox" Text="Text" Foreground="{Binding Brush1, Mode=OneWay}"/> Mã C# : //Tạo một lớp MyColors đã thực thi giao tiếp INotifyPropertyChanged. MyColors textcolor = new MyColors(); // Brush1 thiết lập một SolidColorBrush với giá trị màu Red. textcolor.Brush1 = new SolidColorBrush(Colors.Red); // Thiết lập DataContext của MyTextBox. MyTextBox.DataContext = textcolor; Khi sử dụng DataContext trong mã C# trên đây, nĩ cho phép các thẻ UI thừa kế thơng tin về dữ liệu nguồn. Ví dụ giống như trong ASP.NET bạn sử dụng phương thước gán DataSouce để hiển thị dữ liệu trên một Grid. o Các phương thức điều hướng của luồng dữ liệu Mỗi một kiểu binding data đều cĩ một phương thức điều hướng luồng dữ liệu(Mode propery). Cái này quyểt định khi nào và làm thế nào để dữ liệu chảy tràn. Cĩ 3 phương thức điều hướng luồng dữ liệu sau - OneTime: binding dữ liệu tới target (giao diện người dùng) một lần và sau đĩ kết thúc kết nối khơng binding nữa. Phương thức này phù hợp khi hiển thị dữ liệu mà ít khi hoặc khơng bao giờ cần thay đổi. - OneWay: Binding dữ liệu tới target và giữ nĩ đến khi Source (nguồn dữ liệu) thay đổi thì target cũng thay đổi theo. Phương thức này phù hợp khi trình bày dữ liệu mà người dùng khơng được phép thay đổi - TwoWay: Binding dữ liệu tới target và giữ nĩ đến khi source thay đổi thì target cũng thay đổi theo, nhưng khi target thay đổi thì source cũng thay đổi theo. Phương thức này phù hợp khi trình bày dữ liệu mà cho phép người dùng thay đổi dữ liệu nguồn o Change Notification Để cho hợp lệ với các thay đổi giá trị giữa Source object và Target objects thì chúng ta phải thực thi một interface là InotifyPropertyChanged. Trong InotifyPropertyChanged cĩ cung cấp một event PropertyChanged. Trong ví dụ dưới đây. Class MyColors thực thi giao tiếp InotifyPropertyChanged cho phương thức OneWay namespace DataBinding { //Tao mot class thua ke interface INotifyPropertyChanged public class MyColors : INotifyPropertyChanged { private SolidColorBrush _Brush1; Infoway Solutions CHƯƠNG VII: LÀM VIỆC VỚI DỮ LIỆU TRONG SILVERLIGHT 3 // Khai bao su kien PropertyChanged. public event PropertyChangedEventHandler PropertyChanged; //Tao thuoc tinh cua SolidColorBrush public SolidColorBrush Brush1 { get { return _Brush1; } set { _Brush1 = value; // Goi NotifyPropertyChanged khi thuoc tinh nguon duoc cap nhap NotifyPropertyChanged("Brush1"); } } public void NotifyPropertyChanged(string propertyName) { if (PropertyChanged != null) { PropertyChanged(this, new PropertyChangedEventArgs(propertyName)); } } } } 3 Sử dụng Isolated Storage Silverlight dùng Isolated Storage như một hệ thống file ảo để lưu trữ dữ liệu trong một thư mục ẩn trên máy tính của bạn. Nĩ chia dữ liệu vào làm 2 phân riêng biệt: Phần thứ nhất chứa các thơng tin quản lý như dung lượng cho phép và phần thứ 2 chứa dữ liệu thực sự. Mỗi ứng dụng Silverlight được phân bố một vùng riêng trong hệ thống lưu trữ này với dung lượng lưu trữ mặc nhiên là 1 MB. o Ưu điểm: - Isolated Storage là một thay thế tuyệt vời cho cookie, đặc biệt là nếu bạn đang làm việc với một tập lớn dữ liệu. Một số ví dụ về khả năng của Isolated Storage bao gồm undo lại một số thao tác của ứng dụng, hay giỏ hàng, các cài đặt về cửa sổ hay bất kỳ cài đặt nào mà bạn muốn truy cập vào lần nạp tiếp theo. - Isolated Storage lưu trữ theo người dùng cho phép các ứng dụng lưu giữ các cài đặt cho từng người dùng riêng biệt. o Một số vấn đề cĩ thể xảy ra: - Người quản trị cĩ thể đặt giới hạn đĩa trên mỗi người dùng và assembly, khơng cĩ bất kỳ cảnh báo nào về khơng gian trống cịn lại. Vì lý do này, bạn nên kiểm tra và bắt các ngoại lệ trong ứng dụng của bạn. - Dù rằng Isolated Storage được đặt trong một thư mục ẩn trong hệ thống, nhưng khơng cĩ nghĩa người dùng khơng thể tìm ra thư mục này, do vậy Isolated Storage khơng hồn tồn an tồn và người dùng cĩ thể thay đổi hoặc xĩa các file. Tuy nhiên, nếu muốn người dùng khơng thể thay đổi các file, bạn cĩ thể dùng các lớp mã hĩa để mã lại các file này trước khi lưu. - Các máy tính cĩ thể bị khĩa bởi các chính sách bảo mật và các ứng dụng sẽ khơng thể lưu được vào IsolatedStorage. Cụ thể hơn, bạn cần cĩ IsolatedStorageFilePermission để cĩ thể làm việc được với IsolatedStorage Infoway Solutions CHƯƠNG VII: LÀM VIỆC VỚI DỮ LIỆU TRONG SILVERLIGHT 4 Giờ hãy xem qua ví dụ về việc lưu và đọc dữ liệu từ IsolatedStorage. Nhớ rằng bạn cần dùng using để tham chiếu đến namespace System.IO.IsolatedStorage cũng như là System.IO. Infoway Solutions CHƯƠNG VII: LÀM VIỆC VỚI DỮ LIỆU TRONG SILVERLIGHT 5 using System.Windows.Controls; using System.IO.IsolatedStorage; using System.IO; using System; namespace Samples_Chap7 { public partial class Page : UserControl { public Page() { InitializeComponent(); //Luu du lieu vao file dulieu.txt SaveData("Day la du lieu cua toi", "dulieu.txt"); //Lay du lieu tu file dulieu.txt string test = LoadData("dulieu.txt"); } private void SaveData(string data, string fileName) { //Lay Isolated Storage cua nguoi dung danh cho ung dung using (IsolatedStorageFile isf = IsolatedStorageFile.GetUserStoreForApplication()) { using (IsolatedStorageFileStream isfs = new IsolatedStorageFileStream(fileName, FileMode.Create, isf)) { using (StreamWriter sw = new StreamWriter(isfs)) { //Luu du lieu sw.Write(data); sw.Close(); } } } } private string LoadData(string fileName) { string data = String.Empty; //Lay Isolated Storage cua nguoi dung danh cho ung dung using (IsolatedStorageFile isf = IsolatedStorageFile.GetUserStoreForApplication()) { using (IsolatedStorageFileStream isfs = new IsolatedStorageFileStream(fileName, FileMode.Open, isf)) { using (StreamReader sr = new StreamReader(isfs)) { string lineOfData = String.Empty; while ((lineOfData = sr.ReadLine()) != null) //Doc du lieu data += lineOfData; } } } return data; } } } Infoway Solutions CHƯƠNG VII: LÀM VIỆC VỚI DỮ LIỆU TRONG SILVERLIGHT 6 4 Khái quát về làm việc với dữ liệu XML, LINQ to XML Trong Silverlight bạn cĩ thể phân tích dữ liệu XML bằng một trong hai cách là LINQ to XML hoặc XmlReader Đối với những tài liệu XML lớn địi hỏi việc tải dữ liệu về tốn nhiều bộ nhớ trong làm giảm hiệu suất chương trình. Trong trường hợp này chúng ta nên sử dụng XmlReader với những đặc tính như đọc dữ liệu nhanh, forward-only, non-caching parser. Ngược lại với những tài liệu XML nhỏ hơn bạn nên sử dụng LINQ to XML, nĩ cung cấp những tính năng và tiện ích hữu dụng hơn XmlReader Trong phần này chúng tơi sẽ hướng dẫn các bạn về cách xử lý dữ liệu xml với LINQ to XML( Silverlight). o Khái quát về LINQ to XML LINQ to XML cũng giống như Document Object Model(DOM) trong đĩ nĩ đem tài liệu XML này vào trong bộ nhớ. Bạn cĩ thể truy vấn và thay đổi tài liệu này, sau khi thay đổi nĩ bạn cĩ thể lưu nĩ và một file hoặc chuyển đổi hĩa nĩ (Serialize) rồi gửi nĩ thơng qua mạng Internet. Tuy nhiên LINQ to XML khác biệt so với DOM ở chỗ: Nĩ cung cấp một đối tượng mới nhẹ nhàng hơn và dễ dàng làm việc với chúng hơn, ngồi ra LINQ to XML cịn là sự cải tiến của ngơn ngữ Visual C# 2008. Một lợi thế quan trọng nhất của LINQ to XML là nĩ tích hợp với Language-Integrated Query (LINQ). Với sự tích hợp này nĩ cho phép bạn viết câu truy vấn tài liệu XML khi ở trong bộ nhớ để trả về tập hợp các Element và attribute. LINQ to XML cĩ thể so sánh được với các chức năng của XPath và Xquery. o Tạo một XAML động với LINQ to XML Trong mục này chúng ta sẽ chỉ rõ các tạo một control TextBlock bằng LINQ to XML. Trước tiên để tùy chỉnh project silverlight trong Visual Studio chúng ta chạy ví dụ dưới đây 1. Trong Solution Explorer, thêm assembly reference tới System.Xml.Linq.dll 2. Thay đổi nội dung file page.xaml của bạn theo mã dưới đây <UserControl x:Class="SilverlightApplication1.Page" xmlns="" xmlns:x="" Width="400" Height="300"> 3. Trong file page.xaml.cs thêm các khai báo using sau đây using System.Windows.Markup; using System.Xml.Resolvers; using System.Xml; using System.Xml.Linq; using System.IO; using System.Text; Dưới đây là ví dụ chi tiết về tạo một đối tượng XElement và lưu nĩ với thơng tin liên hệ. // Tao XElement de luu thong tin lien he ban be XElement contacts = new XElement("Contacts", new XElement("Contact1", new XElement("Ten", "Pham Chi Cuong"), new XElement("DienThoai", "0906 123 480"), new XElement("DiaChi", new XElement("DuongPho", "Nguyen Hong"), Infoway Solutions CHƯƠNG VII: LÀM VIỆC VỚI DỮ LIỆU TRONG SILVERLIGHT 7 new XElement("ThanhPho", "HaNoi") ) ), new XElement("Contact2", new XElement("Ten", "Tran Duy Bien"), new XElement("DienThoai", "0904 252 161"), new XElement("DiaChi", new XElement("DuongPho", "Pham Van Dong"), new XElement("ThanhPho", "HaNoi") ) ) ); // Tao TextBlock1 // Luu y rang Element nay phai khai bao 2 XAML namespace XElement textBlock1 = XElement.Parse( @"<TextBlock xmlns=' xmlns:x=' TextWrapping= 'Wrap' Width = '400' Canvas.Top = '10' Text=''/>"); // Lay child Element cua contact1 XElement contact1 = contacts.Element("Contact1"); // Gan gia tri vao thuoc tinh Text o cuoi cung voi noi dung cua cac contact trong xml textBlock1.LastAttribute.SetValue(contact1.ToString()); // Lay child element thu hai XElement contact2 = contacts.Element("Contact2"); // Tao TextBlock2 // Luu y rang Element nay phai khai bao 2 XAML namespace XNamespace xmlns = ""; XElement textBlock2 = new XElement(xmlns + "TextBlock", new XAttribute(XNamespace.Xmlns + "x", ""), new XAttribute("Canvas.Top", 250), new XAttribute("Width", "600"), new XAttribute("Text", contact2.ToString()) ); // Them TextBlock1 vao trong trang LayoutRoot.Children.Add(XamlReader.Load(textBlock1.ToString()) as UIElement); // Them TextBlock2 vao trong trang LayoutRoot.Children.Add(XamlReader.Load(textBlock2.ToString()) as UIElement); o Cách load file XML từ một URI bất kỳ 1. Tạo một đối tượng WebClient, thêm trình xử lý (handler), Gọi phương thức OpenReadAsync. Làm theo mã lệnh dưới đây WebClient wc = new WebClient(); wc.OpenReadCompleted += wc_OpenReadCompleted; wc.OpenReadAsync(new Uri(uriString)); 2. Thực thi hàm callback wc_OpenReadCompleted Infoway Solutions CHƯƠNG VII: LÀM VIỆC VỚI DỮ LIỆU TRONG SILVERLIGHT 8 private void wc_OpenReadCompleted(object sender, OpenReadCompletedEventArgs e) { //Kiem tra thuoc tinh Error cho cac loi if (e.Error != null) { OutputTextBlock.Text = e.Error.Message; return; } //Neu khong co loi, Lay du lieu stream ve va phan tich chung toi XDocument thong qua phuong thuc Load using (Stream s = e.Result) { XDocument doc = XDocument.Load(s); OutputTextBlock.Text = doc.ToString(SaveOptions.OmitDuplicateNamespaces); } } 5 Truy cập dữ liệu SQL Server với WCF Trong phần này chúng ta sẽ xây dựng một ứng dụng nhỏ để kết nối với CSDL SQL Server. Để hồn thiện được ứng dụng này chúng ta cần tập hợp được những kỹ năng sau - Kết nối tới một WCF Web Service - Sử dụng LINQ để truy vấn và trả về dữ liệu

Các file đính kèm theo tài liệu này:

  • pdftailieu.pdf
Tài liệu liên quan