Tài liệu Đồ án Tổng quan về silverlight: Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 1
Nguyễn Anh Việt
Lưu Xuân Việt
Phần I:
TỔNG QUAN VỂ SILVERLIGHT
Chương 1:
GIỚI THIỆU VỀ SILVERLIGHT
I. KHÁI QUÁT SILVERLIGHT
Microsoft Silverlight là một công nghệ đa nền, đa trình duyệt dựa trên nền .NET
dùng để xây dựng và phát triển một thế hệ ứng dụng Web và thiết bị mới, đầy tính tương
tác và hỗ trợ tối đa về media (phương tiện truyền thông). Hiện nay Silverlight đang có hai
phiên bản là Silverlight 1.0 dùng phát triển ứng dụng bằng ngôn ngữ Javascript và một
phiên bản Silverlight 2.0 bằng các ngôn ngữ .NET framework (khung) như C# hay
VB.NET. Bên cạnh đó công nghệ Silverlight còn được hỗ trợ bởi ngôn ngữ đánh dấu
XAML (extensible application markup language – Ngôn ngữ đánh dấu mở rộng) đầy sức
mạnh trong việc thể hiện giao diện người dùng. Có thể nói công nghệ Silverlight đã thống
nhất được tất cả các khả năng của server, Web và ứng dụng desktop, của code .NET, c...
140 trang |
Chia sẻ: hunglv | Lượt xem: 1533 | Lượt tải: 1
Bạn đang xem trước 20 trang mẫu tài liệu Đồ án Tổng quan về silverlight, để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 1
Nguyễn Anh Việt
Lưu Xuân Việt
Phần I:
TỔNG QUAN VỂ SILVERLIGHT
Chương 1:
GIỚI THIỆU VỀ SILVERLIGHT
I. KHÁI QUÁT SILVERLIGHT
Microsoft Silverlight là một công nghệ đa nền, đa trình duyệt dựa trên nền .NET
dùng để xây dựng và phát triển một thế hệ ứng dụng Web và thiết bị mới, đầy tính tương
tác và hỗ trợ tối đa về media (phương tiện truyền thông). Hiện nay Silverlight đang có hai
phiên bản là Silverlight 1.0 dùng phát triển ứng dụng bằng ngôn ngữ Javascript và một
phiên bản Silverlight 2.0 bằng các ngôn ngữ .NET framework (khung) như C# hay
VB.NET. Bên cạnh đó công nghệ Silverlight còn được hỗ trợ bởi ngôn ngữ đánh dấu
XAML (extensible application markup language – Ngôn ngữ đánh dấu mở rộng) đầy sức
mạnh trong việc thể hiện giao diện người dùng. Có thể nói công nghệ Silverlight đã thống
nhất được tất cả các khả năng của server, Web và ứng dụng desktop, của code .NET, của
ngôn ngữ hình thể và ngôn ngữ truyền thống và sức mạnh của Windows Presentation
Foundation (WPF). Để cuối cùng tạo ra một ứng dụng mà người dùng phải thấy thích.
Một số người cho rằng công nghệ Silverlight của Microsoft sẽ là “sát thủ” của Adobe
Flash. Nhưng hiện tại thì chưa thể biết được điều gì, vì cả hai công nghệ này đều được sử
dụng bằng plug in của trình duyệt, cả hai đều hỗ trợ đồ họa vector, âm thanh, phim ảnh,
animation và ngôn ngữ script.
Về mặt căn bản thì công nghệ này có sự khác biệt. Trong khi Flash sử dụng định dạng
nhị phân semi-open, thì Silverlight dựa trên nền WPF. Thực tế trước khi công nghệ mới
này của Microsoft được đặt tên là Silverlight thì nó đã có tên mã là WPF/e (Windows
Presentation Foundation Everywhere).
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 2
Nguyễn Anh Việt
Lưu Xuân Việt
Điểm quan trọng nhất trong công nghệ Silverlight là hệ thống đồ họa con được hỗ trợ
bởi một nhánh trong WPF, bao gồm các đoạn mã thể hiện âm thanh, phim ảnh.
Được công bố tại Mix’07 vào tháng 5 năm 2007, SilverLight mang đến cho thế giới
một cơn bão với một cái nhìn về Adobe Flash giống như ứng dụng Internet (RIAs) được
xây dựng trên một nền cơ bản, mở ra cách tiếp cận với HTML và XAML sử dụng các
công cụ như VisualStudio .NET và Microsoft Blend.Ý tưởng cho SilverLight thì không
có gì mới, Microsoft đang nói về công nghệ gọi là WPF/e trước đây hơn 1 năm.Quan tâm
đầy đủ thì đây là sự lẫn lộn xung quanh WPF/e có nghĩa là gì, tên cần thay đổi với cái gì
đó hoàn toàn khác, một tên mà không liên quan tới WPF/e với khách hàng thông minh,
thế hệ kế tiếp của nền Giao diện người dùng (UI) Nền tảng biểu diễn Windows( WPF).
Ý tưởng của chữ e ở cuối WPF là chuyển WPF đi khắp mọi nơi. Nhưng đây đơn
giản không phải là một trường hợp. WPF này là một phần nhân của .NET 3.0 và yêu cầu
30MB khi chạy. WPF/e có 2MB khi download, chạy trong bộ trình duyệt, và chạy trên
nhiều nền tảng khác nhau.Và nhiều nền ở đây không có nghĩa là WindowsXP và
WindowsVista; Nó có nghĩa là Windows và Apple Macintosh.Nó hoạt động trên bộ trình
duyệt web safari trong Apple Macintosh được phục vụ từ một Máy chủ web Apache chạy
trên Linux. Tên WPF/e không phải là đại diện đầy đủ cho việc đáng kinh ngạc của công
nghệ mới này, vì vậy mà SilverLight đựơc công bố như tên mới tại Mix’07.
Kiến trúc của Silverlight cũng khá phức tạp. Hệ thống đồ họa đảm bảo mọi thứ cho
giao diện người dùng, như animation, text, âm thanh, hình ảnh. Plug-in được tích hợp vào
trình duyệt để thể hiện ứng dụng Silverlight, để giao tiếp bằng JavaScript DOM và ứng
dụng Silverlight có thể gọi các hàm trên server như một dạng web service.
Dù người phát triển ứng dụng là người phát triển web hay người thiết kế đồ họa thì
Silverlight đều tạo điều kiện tốt nhất để người đó có thể phát huy tối đa khả năng của
mình.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 3
Nguyễn Anh Việt
Lưu Xuân Việt
1. Silverlight (Ánh sáng bạc) là gì?
SilverLight đơn giản là một nền Web được xây dựng để chạy RIAs. Một phần của
nền web đó thực chất là một Plug-in mà chạy bên trong bộ trình duyệt.
- Silverlight là một nền chéo, nền trình duyệt chéo của RIAs
- Silverlight hỗ trợ phát lại Windows Media và các file âm thanh trên PC và MAC
mà không phụ thuộc vào Windows Media Player
- Sử dụng XAML, HTML, và JavaScript, nó hỗ trợ đồ họa, hoạt ảnh, đa phương
tiện và mở rộng ra hơn những gì mà AJAX có thể hỗ trợ.
- Gói lắp đặt nhỏ hơn 6MB.
- XAML được tạo ra cho SilverLight có thể được sử dụng trong những ứng dụng
WPF
Microsoft Silverlight là một plug-in dựa trên .NET, độc lập với nền tảng và trình
duyệt cho phép phát triển các ứng dụng đa phương tiện và nặng về tương tác trên Web.
Silverlight cung cấp một mô hì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ữ trên nền .NET như Visual Basic và C#, và có thể tích hợp
vào các ứng dụng Web sẵn có. Các khả năng về đa phương tiện của Silverlight bao gồm
truyền tải dữ liệu hình ảnh, âm thanh chất lượng cao một cách nhanh chóng và hiệu quả
về chi phí trên tất cả các trình duyệt chính như FireFox, Safari, và Internet Explorer chạy
trên nền Mac hoặc Windows. Với Expression Studio và Visual Studio, nhà phát triển và
nhà thiết kế có thể hợp tác một cách hiệu quả, dùng các kỹ năng hiện có để phát triển các
sản phẩm Web tương lai.
2. Silverlight – Ứng dụng cơ bản với sự phong phú trong đồ họa và tương tác với
người dùng (User).
Người lập trình Web và thiết kế đồ họa có thể tạo ra nhiều ứng dụng Silverlight cơ
bản với sự đa dạng trong cách thể hiện. Ta cũng có thể sử dụng Silverlight Markup để tạo
ra Media và Graphics và vận dụng chúng với sự đa dạng của ngôn ngữ và quản lý Code.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 4
Nguyễn Anh Việt
Lưu Xuân Việt
Silverlight cũng cho phép bạn sử dụng những công cụ chất lượng chuyên nghiệp như
Visual Studio cho coding và Microsoft Expression Blend cho thiết kế hình ảnh và giao
diện.
3. Nét đặc trưng của Silverlight.
Silverlight kết hợp nhiều kỹ thuật trong việc phát triển một nền tảng đơn mà cho
phép ta chọn lựa những công cụ và ngôn ngữ lập trình thích hợp mà ta cần tới. Các tính
năng của Silverlight:
- WPF và XAML: Silverlight gồm có một tập kỹ thuật con WPF (Windows
Presentation Foundation) gồm nhiều thành phần mở rộng trong trình duyệt dành
cho UI. WPF cho phép ta tạo ra những hình ảnh, hoạt cảnh (amination), media và
nhiều nét đặc trưng phong phú trên máy trạm (Client), phần mở rộng của trình
duyệt cơ bản UI ngoại trừ những gì chỉ có hiệu lực với HTML. XAML (Extensible
Application Markup Language) cung cấp một cú pháp khai báo “Markup” tạo ra
các phần tử để xây dựng những ứng dụng Silverlight cơ bản như: text, controls,
graphics, và animation.
- Mở rộng với JavaScipt. Silverlight không những cung cấp những phần mở rộng
của các ngôn ngữ kịch bản trong nhiều trình duyệt phổ biến mà còn cung cấp các
“Control” bên trong trình duyệt UI, bao gồm cả khả năng làm việc với các phần tử
WPF.
- Hỗ trợ những nền tảng (platform), trình duyệt đa nhiệm. Silverlight chạy trên hầu
hết các trình duyệt đa nhiệm (Bất kỳ nền tảng nào). Chúng ta có thể thiết kế và
trình bày mà không phải lo lắng về vấn đề trình duyệt nào hoặc nền tảng nào
(platform) và người sử dụng có hay không.
- Tương thích với mọi ứng dụng hiện tại. Silverlight tương thích hoàn toàn với với
mã JavaScript, ASP.NET AJAX hiện nay kể cả những hàm mở rộng ta đã khởi tạo.
Ta có thể khởi tạo một tài nguyên cơ bàn trên máy chủ (Server) trong ASP.NET và
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 5
Nguyễn Anh Việt
Lưu Xuân Việt
sử dụng khả năng của AJAX trong ASP.NET để tương tác với tài nguyên đó mà
không cần ngắt người dùng.
- Truy xuất kiểu lập trình .NET Framework và những công cụ kết hợp. Ta có thể tạo
một ứng dụng Silverlight cơ bản sử dụng các ngôn ngữ chức năng như:
IronPython, hay ngôn ngữ gần gũi hơn như: C#, Visual Basic. Ta cũng có thể sử
dụng những công cụ triển khai như Visual Studio để tạo những ứng dụng
Silverlight cơ bản.
- Mạng hỗ trợ. Silverlight được hỗ trợ HTTP qua giao thức TCP. Ta có thể kết nối
những dịch vụ: WCF, SOAP, hoặc ASP.NET AJAX và thu nhận dữ liệu XML,
JSON, hoặc RSS.
4. Chạy Silverlight cơ bản.
- Ứng dụng Silverlight cơ bản chạy trên các trình duyệt. Những ứng dụng được tạo
ra trong Silverlight chắc chắn sẽ chạy được trên các trình duyệt mà không cần phải
thêm một đoạn mã (Code) mới nào. Để chạy được những ứng dụng Silverlight cơ bản
này, người dùng (User) cần đến 1 trình nhúng (Plug-in) nhỏ vào trong trình duyệt.
Plug-in này hoàn toàn miễn phí. Nếu người dùng chưa cài đặt Plug-in, chúng sẽ tự
động nhắc người dùng cài đặt vào. Việc tải về và cài đặt chỉ trong vòng vài giây và
phụ thuộc vào việc mong muốn hay loại bỏ việc cài đặt phía người dùng.
5. Tạo một ứng dụng Silverlight cơ bản.
Chúng ta có thể tạo một ứng dụng Silverlight cơ bản sử dụng bất kỳ .NET
Framework nào với sự hỗ trợ của ngôn ngữ (bao gồm Visual Basic, C#, và JavaScript).
Visual Studio 2008 và Expression Blend cung cấp và hỗ trợ cho sự phát triển ứng dụng
Silverlight. Chúng ta cũng có thể tạo một trang Web mà sử dụng cả hai phần tử WPF và
HTML với Silverlight. Cũng giống như HTML, XAML cũng cho phép ta tạo ra những UI
cho những nền ứng dụng Web với những cú pháp đã khai báo. Nhưng có sự khác biệt là
XAML cung cấp nhiều phần tử mạnh mẽ hơn.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 6
Nguyễn Anh Việt
Lưu Xuân Việt
II. BẢN ĐỒ SILVERLIGHT
Chủ đề này cung cấp một cái nhìn tổng thể về những nét đặc trưng chính trong việc
phát triển ứng dụng cơ bản Silverlight. Nó bao gồm những bước phổ biến để tạo một ứng
dụng cơ bản Silverlight với những đoạn code ví dụ giúp bạn trong những bước đầu viết
code.
Chủ đề này bao gồm những phần sau:
• Prerequisites
• Integrating Silverlight into Applications
• XAML
• Layout
• Controls
• Adding Code Logic
• Dynamic Languages
• Graphics
• Media and Animation
• Data
• Networking
• Related Topics
1. Yêu cầu cơ bản (Prerequisites)
Bạn có thể chạy tất cả các ví dụ có trong chủ đề này mà không cần cài đặt thêm bất
cứ cái gì ngoại trừ trình thực thi Silverlight 2. Bên cạnh đó, nếu bạn muốn thêm vào hay
sửa đổi ví dụ, bạn sẽ cần phải thêm những công cụ Silverlight và làm việc với một đề án
(project) Silverlight.
Chủ đề này sử dụng ứng dụng API cho Silverlight. Bạn cũng cần phải trình bày
ứng dụng nền Silverlight sử dụng JavaScript API cho Silverlight.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 7
Nguyễn Anh Việt
Lưu Xuân Việt
2. Hòa nhập Silverlight bên trong những ứng dụng (Integrating Silverlight into
Applications)
Một ứng dụng nền Silverlight là nó chứa đựng những gì đã được tải lên bởi trình
nhúng Silverlight (Silverlight plug-in) lên trên một trang HTML. Trình nhúng Silverlight
có thể lấp đầy trang HTML hoặc chỉ một phần trống nào đó. Mặc định, một đề án Visual
Studio cho phép trình nhúng chiếm 100% chiều dài và chiều rộng một trang.
Nếu bạn muốn chỉ 1 phần ứng dụng sử dụng Silverlight, bạn có thể gọi chúng
trong trang HTML từ đoạn mã Silverlight và ngược lại.
3. XAML
XAML là một ngôn ngữ dựa trên XML, ngôn ngữ này cho phép bạn có thể xây
dựng giao diện của các ứng dụng rất dễ dàng và nhanh chóng, bạn chỉ cần khai báo các
thành phần có trên giao diện của ứng dụng cùng với các thuộc tính của nó, khi chạy
chương trình sẽ hiển thị giống như bạn đã khai báo. Điều này cho phép tách bạch được
giữa việc thiết kế giao diện và việc hiện thực hóa các tính năng.
XAML có trong Silverlight là một tập con của XAML trên .NET 3.0, trong đó đã
bị hạn chế một số tính năng như đồ họa 3D nhằm giữ tính tương thích trên nhiều nền tảng
và trình duyệt khác nhau.
Bạn có thể tạo tất cả các UI của mình trong XAML, hoặc bạn có thể sử dụng
Microsoft Expression Blend để xây dựng các UI trong ứng dụng của mình. Expression
Blend là một bộ công cụ thiết kế với giao diện thiết kế WYSIWYG để tạo nên những
trình ứng dụng nền Silverlight. Expression Blend sinh ra một file XAML mà bạn có thể
dùng để soạn thảo trực tiếp. Bạn cũng có thể móc nối những sự kiện và viết code-behind
với Expression Blend.
4. Layout
Khi tạo một ứng dụng nền Silverlight, điều đầu tiên bạn cần phải làm là xác định
việc bố trí giao diện (UI) như thế nào. Silverlight cung cấp 3 loại panel bố trí để bạn có
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 8
Nguyễn Anh Việt
Lưu Xuân Việt
thể sử dụng. Trong 3 loại đó, panel Grid có tính chất mềm dẻo và mạnh mẽ nhất, do đó
giá trị mặc định ban đầu là Grid
Container Mô tả
Canvas Vị trí tuyệt đối của những phần tử con trong không gian x,y.
StackPanel
Vị trí tương đối của 1 phần tử con với một phần tử khác theo chiều
ngang hoặc chiều dọc.
Grid Vị trí của những phần tử con trong hàng và cột.
Trong ví dụ dưới đây, một phần tử hình chữ nhật là chỗ ô 1,1 của 1 Grid. Grid sử dụng
chỉ mục bắt đầu là 0, vì vậy hình chữ nhật xuất hiện ở ô phải-dưới.
XAML
<Rectangle Fill="Red" Width="150" Height="100"
Grid.Column="1" Grid.Row="1"/>
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
Hình 1
5. Control
Control trong Silverlight cho phép bạn đưa ra những chỉ mục chính, hoặc những
control khác và bạn có thể thiết kế thay đổi trạng thái cách hiển thị đến người dùng.
Những loại Control trong hàm xử lý từ những phần tử mà cho phép người dùng tương tác
như Button hoặc TextBox tới những phần tử bố trí những thông tin phức tạp hơn như
DataGrid.
Xuyên suốt Silverlight với những ví dụ mẫu mặc định cho mỗi loại Control và thấy
được cách dùng những Control như thế nào. Tuy nhiên, bạn cũng có thể tạo nên những
mẫu riêng thay đổi sự xuất hiện và cách cách xử lí nhìn trực quan hơn đối với tất cả các
Control.
Tiếp theo ví dụ ở trên, Chúng ta thêm một Button vào ô 0,0 của Grid.
XAML
SVTH: Thân Hoàng Lộc Trang 9
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
<Button Height="25" Width="100" Grid.Column="0"
Grid.Row="0"/>
<Rectangle Fill="Red" Width="150" Height="100"
Grid.Column="1" Grid.Row="1"/>
Hình 2
SVTH: Thân Hoàng Lộc Trang 10
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 11
Nguyễn Anh Việt
Lưu Xuân Việt
6. Thêm những Code Logic (Adding Code Logic)
Mặc định, trong một đề án Visual Studio gồm có một tập tin mã (code file), đôi khi
sẽ gọi một tập tin code behind. Tập tin code thuần một ngôn ngữ và được Silverlight hỗ
trợ (Support) trong suốt quá trình thực thi (CLR – Common Language Runtime) ví dụ
như: C# hoặc Visual Basic.
Tên của tập tin Code-Behind là Page.xaml và nó gắn liền với loại ngôn ngữ đã được chọn
(Trong ví dụ này là Page.xaml.cs). Tập tin Code-Behind là nơi mà chúng ta có thể thay
đổi cấu trúc logic những đối tượng trong XAML. Chúng ta có thể tạo những đối tượng UI
trong đoạn code và thêm chúng lên cây hiển thị các phần tử. Trong việc thêm vào này,
chúng tạo nên những lớp bên trong tập tin code-behind (Hoặc bất kỳ tập tin code nào
trong đề án) có thể truy xuất được trong XAML.
Trong ví dụ sau chúng ta thêm vào một sự kiện Click nhằm thay đổi màu của hình chữ
nhật thành màu xanh.
Trong XAML, thêm một sự kiện click vào Button và thuộc tính x:Name vào Rectangle.
X:Name cho phép chúng tham chiếu vào trong Rectangle trong tập tin Code-Behind:
XAML:
<Button Height="25" Width="100" Grid.Column="0" Grid.Row="0"
Click="Button_Click"/>
<Rectangle x:Name="rect1" Fill="Red" Width="150"
Height="100" Grid.Column="1" Grid.Row="1"/>
Trong file Code-Behind, khai báo quản lý sự kiện click (Click event Handler):
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 12
Nguyễn Anh Việt
Lưu Xuân Việt
C#:
private void Button_Click(object sender, RoutedEventArgs e)
{
rect1.Fill = new SolidColorBrush(Colors.Blue);
}
7. Ngôn ngữ chức năng (Dynamic Languages)
Những công cụ trong Visual Studio cho Silverlight bao gồm ngôn ngữ thực thi
chức năng (Dynamic Language Runtime - DLR) cho phép người dùng sử dụng các ngôn
ngữ chức năng như Python và Ruby để viết ứng dụng nền Silverlight. Ngôn ngữ chức
năng là những gói mã nguồn ( Source code) không biên dịch trong quá trình lắp, nối
(assemblies) và mã (code) của chúng có thể được sinh ra và biên dịch trong quá trình thực
thi. Chúng tương thích tốt và mền dẻo trong quá trình tương tác trình bày. Silverlight bao
gồm 3 ngôn ngữ chức năng: IronPython, IronRuby, and Managed Jscript.
8. Đồ họa (Graphics)
Silverlight cung cấp nhiều tùy chọn trong việc thêm vào những tính năng trực quan
trong ứng dụng của bạn. Bạn có thể sử dụng thuật vẽ (Drawing), khuôn hình (Shapes),
đường vẽ (paths) và những hình học phức tạp. Khu vực khai báo hình học có thể được lấp
đầy bởi nhiều hiệu ứng như: hình ảnh, độ nghiêng màu hoặc những Video clip.
Bạn cũng có thể thêm vào hình ảnh hoặc hiệu ứng hình ảnh trong ứng dụng.
Silverlight cũng tính đến cách nhìn theo chiều sâu (Deep Zoom) cho phép bạn dễ dàng
nhìn thấy và quét góc nhìn chi tiết những hình ảnh.
Ví dụ đầy đủ về hình chữ nhật với những bút kẻ nghiêng (linear gradient brush):
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 13
Nguyễn Anh Việt
Lưu Xuân Việt
XAML:
<Rectangle x:Name="rect1" Width="150" Height="100"
Grid.Column="1" Grid.Row="1">
9. Media và Animation (Media and Animation)
Ngoài việc thêm vào những hình tĩnh, bạn có thể thêm vào những ảnh động, âm
thanh (audio) và video nhằm tạo nên nhiều tính năng và sự tương tác cho ứng dụng.
Tiếp theo ví dụ tạo hình chữ nhật ở ví dụ trước. Chúng sẽ tự phóng to và thu nhỏ
cho tới khi nhấp vào button Stop.
XAML:
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 14
Nguyễn Anh Việt
Lưu Xuân Việt
<DoubleAnimation Storyboard.TargetName="rect1"
Storyboard.TargetProperty="Height"
From="0" To="100"
AutoReverse="True" Duration="0:0:02"
RepeatBehavior="Forever"/>
<DoubleAnimation Storyboard.TargetName="rect1"
Storyboard.TargetProperty="Width"
From="0" To="100"
AutoReverse="True" Duration="0:0:04"
RepeatBehavior="Forever"/>
<Button Height="25" Width="100"
Grid.Column="0" Grid.Row="0"
Content="Stop"
Click="Button_Click"/>
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 15
Nguyễn Anh Việt
Lưu Xuân Việt
<Rectangle x:Name="rect1" Width="150" Height="100"
Grid.Column="1" Grid.Row="1" Loaded="OnLoaded">
<GradientStop Offset="1.0"
Color="Lavender"/>
<Button Height="25" Width="100"
Grid.Column="0" Grid.Row="1"
Content="Start"
Click="Button_Click_1"/>
C#
private void OnLoaded(object sender, RoutedEventArgs e)
{
AnimateRectangle.Begin();
}
private void Button_Click(object sender, RoutedEventArgs e)
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 16
Nguyễn Anh Việt
Lưu Xuân Việt
{
AnimateRectangle.Pause();
}
private void Button_Click_1(object sender, RoutedEventArgs
e)
{
AnimateRectangle.Resume();
}
10. Dữ liệu (Data)
Rất nhiều ứng dụng nền Silverlight làm việc với dữ liệu. Bạn có thể hiển thị bộ dữ
liệu với những Control như DataGrid và ListBox. Trong một UI, bạn có thể sử dụng Data
Binding. Nếu đối tượng data có kết nối với UI, nó sẽ tự động cập nhật và truyền tới UI.
Dữ liệu có thể mang vào trong ứng dụng từ những nguồn (Source) cung cấp dồi
dào. Chẳng hạn như nguồn cung cấp RSS, nhưng thường định dạng theo kiểu XML.
Silverlight bao gồm XmlReader và LINQ dùng cho việc phân tách dữ liệu XML. LINQ
thích hợp cho việc phân tách những phần dữ liệu nhỏ.
11. Hệ thống mạng (Networking)
Silverlight cung cấp vài nét đặc trưng trong sự kết nối truyền thông . Lớp
WebClient điều khiển sự truyền tải nội dung tới máy trạm (Client). Bạn cũng có thể sử
dụng lớp WebClient để gởi và nhận một thông điệp XML đơn giản. Ứng dụng nền
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 17
Nguyễn Anh Việt
Lưu Xuân Việt
Silverlight cũng có thể truy xuất Web Service như là WCF (Windows Communication
Foundation), SOAP, và ASP.NET AJAX
III. KIẾN TRÚC SILVERLIGHT (Silverlight Architecture)
Silverlight không chỉ là một bức tranh đa dạng quyến rũ, tương tác với Web và
chứa đựng Media đến với người dùng cuối (end user). Mà sức mạnh của nó là yêu cầu
nền tảng phát triển nhẹ nên tính linh động cao, nền tảng đa nhiệm, ứng dụng mạng tích
hợp nhiều dữ liệu và dịch vụ từ nhiều nguồn khác nhau. Hơn nữa, Silverlight cho phép
bạn xây dựng những giao diện người dùng với sự thay đổi đáng kể những nét đặc trưng
bởi kinh nghiệm từng trải của người dùng cuối so sánh được với những ứng dụng Web
truyền thống.
Trong khi Silverlight đóng vai trò như là một ứng dụng khách bên cạnh môi trường
thực thi đơn và gói gọn trong 1 kích cỡ nào đó. Và nền tảng phát triển Silverlight hòa
nhập với một số nét đặc trưng tiêu biểu với kỹ thuật phức tạp, chúng tạo nên sự gần gũi
với người lập trình. Để tạo một ứng dụng nền Silverlight hiệu quả, người lập trình cần
phải làm việc và am hiểu kiến trúc nền vững chắc.
Chú ý:
Phiên bản Silverlight 2 hỗ trợ 2 kiểu lập trình: JavaScript API đối với Silverlight
và Quản lý (the Managed) API đối với Silverlight. Quản lý API là một tập con của .NET
FrameWork. Nhiều nét đặc trưng của Silverlight mà chỉ có Managed API mới hỗ trợ
được.
1. Nền tảng Silverlight (The Silverlight Platform) Nền tảng Silverlight gồm có 2 phần
chính: Cài đặt và nâng cấp các thành phần. Được mô tả như bảng sau:
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 18
Nguyễn Anh Việt
Lưu Xuân Việt
Thành phần Mô tả
Các Framework
trình bày chính
Thành phần và dịch vụ định hướng hướng người dùng và UI tương tác
vơi nhau, bao gồm thông tin vào của người dùng, control UI dễ dùng
đối với người sử dụng ứng dụng web, nghe media, quản lý kỹ thuật số,
điều khiển dữ liệu, và đưa ra những nét đặc trưng, gồm định hướng đồ
họa, văn bản, hình động (hoạt ảnh) và hình ảnh. Và cũng bao gồm
phần mở rộng chỉ định những bố cục riêng (sử dụng ngôn ngữ
XAML).
.NET
Framework cho
Silverlight
Một tập hợp con của .NET Framework chứa đựng những thành phần
và thư viện, bao gồm tích hợp dữ liệu control Windows mở rộng, hệ
thống mạng, lớp thư viện cơ bản, tập hợp dữ liệu rác và CLR
(common Language Runtime). Một vài phần của .NET Framework
cho Silverlight là sự triển khai cùng với ứng dụng. Nhiều thư viện
Silverlight (Silverlight Libraries) là sự hợp thành không phải trong lúc
thực thi và trong phần mở rộng của Silverlight SDK. Những thư viện
Silverlight sử dụng sẽ được đóng gói cùng với ứng dụng và được tải
lên trình duyệt. Bao gồm: những Control UI mới, XLINQ, Syndication
(RSS/Atom), XML serialization và DLR (dynamic language runtime)
Cài đặt và cập
nhật (Installer
and updater)
Control một cài đặt và nâng cấp là một tiến trình xử lý đơn của việc
cài đặt ứng dụng lần đầu tiên cho người dùng, và sau đó là hạn chế
việc tác động trực tiếp để chúng tự động cập nhật.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
Hình 3. Bảng mô tả các thành phần hợp thành kiến trúc Silverlight, các thành phần quan
hệ và dịch vụ
SVTH: Thân Hoàng Lộc Trang 19
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 20
Nguyễn Anh Việt
Lưu Xuân Việt
Có những giá trị riêng trong việc thiết lập nối kết các công cụ, kỹ thuật, kể cả
những dịch vụ trong nền Silverlight: chúng dễ dàng giúp người lập trình tạo nên sự phong
phú, khả năng tương tác và ứng dụng mạng. Mặc dù dễ dàng thực hiện việc xây dựng
những ứng dụng sử dụng những công cụ và kỹ thuật web hiện nay. Người lập trình vẫn bị
cản trở bởi những kỹ thuật khó. Kể cả sự không tương thích nền tảng lập trình, sự khác
nhau trong phương thức truyền và định dạng tập tin, và sự khác nhau trong những trình
duyệt Web dẫn đến những trang hồi đáp, những tập lệnh truy xuất khác nhau. Một ứng
dụng Web phong phú có thể chạy hoàn toàn tốt trên một hệ thống và trình duyệt nhưng nó
cũng có thể hoạt động không tốt trên một hệ thống và trình duyệt khác, hoặc không chạy
được. Các mảng kỹ thuật, phương thức truyền và công cụ ngày nay rất rộng, nó rất là có
quy mô…
- Có khả năng tạo những ứng dụng tương tự mà người dùng đã từng trải trên những
trình duyệt và nền tảng đa nhiệm. Vì vậy chúng trông bắt mắt hơn và dễ thực thi
hơn ở bất cứ nơi đâu.
- Sự tích hợp dữ liệu và dịch vụ từ nhiều hệ thống mạng vào trong ứng dụng sử dụng
những lớp .NET Framework và các hàm xử lý quen thuộc.
- Media phong phú, thuyết phục và giao diện gần gũi với người dùng (UI).
- Silverlight dễ dàng tạo dựng cho người phát triển xây dựng những ứng dụng. Bởi
vì nó khắc phục nhiều sự không tương thích trong những kỹ thuật hiện hành và
cung cấp bên trong một nền tảng công cụ tạo dựng phong phú, nền tảng đa nhiệm
và những ứng dụng đồng nhất.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 21
Nguyễn Anh Việt
Lưu Xuân Việt
2. Các thành phần bên trong (Core Presentation Components)
Tính năng Miêu tả
Input
Những xử lý được nhập vào từ những thiết bị phần cứng như: bàn phím,
chuột, bút vẽ (drawing) hoặc một thiết bị nhập khác.
UI rendering
Định hướng mô tả và những ảnh đồ họa bitmap, hình động (animations) và
văn bản (text).
Media
Phát lại với nét đặc trưng và cách quản lý các tập tin audio và video khác
nhau, chẳng hạn như những tập tin với phần mở rộng: .WMP và .MP3.
Controls
Hỗ trợ những control mở rộng mà có thể tùy biến tạo mẫu xuyên xuốt ứng
dụng.
Layout Cho phép bố trí các chứng năng của các thành phần UI.
Data binding Cho phép nối kết những đối tượng và thành phần UI.
DRM Cho phép quản lý số hóa các tài nguyên media.
XAML Cung cấp một sự phân chia và đánh dấu cho XAML.
Bảng mô tả các thành phần bên trong tiêu biểu của nền tảng Silverlight thể hiện trên hình 3
Người phát triển cũng tương tác với Framework thể hiện này bởi sử dụng XAML
chỉ định rõ những chi tiết trình bày. XAML là điểm chính của sự tương tác giữa .NET
Framework và các lớp thể hiện. Người phát triển có thể vận dụng những cách lập trình để
thể hiện các lớp trong cách quản lý code.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 22
Nguyễn Anh Việt
Lưu Xuân Việt
3. .NET Framework cho Silverlight.
Tính năng Miêu tả
Data
Hỗ trợ ngôn ngữ truy vấn đồng nhất (LINQ) và những tính năng
LINQ với XML, cái mà không bị ràng buộc bởi những tiến trình xử
lý hòa nhập và làm việc với những dữ liệu từ nhiều nguồn khác
nhau. Và cũng hỗ trợ sử dụng XML và những lớp sắp xếp trình bày
dữ liệu.
Base class library
(BCL)
Một bộ thư viện .NET Frameword cung cấp những hàm lập trình cần
thiết như: xử lý một chuỗi ký tự (string handling), biểu thức thông
thường, nhập và xuất, ánh xạ, tập hợp và toàn cầu hóa.
Window
Communication
Foundation (WCF)
Cung cấp tính năng đơn giản truy cập dữ liệu và dịch vụ từ xa. Bao
gồm một đối tượng trình duyệt, yêu cầu HTTP và đối tượng trả lời,
hỗ trợ những lĩnh vực giao nhau yêu cầu HTTP, hỗ trợ RSS/Atom
syndication feeds, và hỗ trợ JSON, POX, và những dịch vụ SOAP.
CLR (common
language runtime)
Cung cấp sự quản lý bộ nhớ, dữ liệu rác, kiểm tra tình trang an toàn
và những xử lý ngoại lệ.
WPF (Windows
Presentation
Foundation)
controls
Cung cấp những control phong phú như: Button, Calendar,
CheckBox, DataGrid, DatePicker, HyperlinkButton, ListBox,
RadioButton, và ScrollViewer.
DLR (dynamic
language runtime)
Hỗ trợ biên dịch những chức năng và thi hành những ngôn ngữ kịch
bản như JavaScript và IronPython trong những chương trình ứng
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 23
Nguyễn Anh Việt
Lưu Xuân Việt
dụng nền Silverlight. Bao gồm những mẫu gắn kết trong việc thêm
vào, hỗ trợ sử dụng những ngôn ngữ khác với Silverlight.
Bảng mô tả danh sách từng phần của .NET Framework với những nét đặc trưng thể hiện
trên hình 3.
Bộ .NET Framework cho Silverlight là một tập hợp con của bộ .NET Framework
đầy đủ. Nó cung cấp những cái mạnh mẽ cần thiết, định hướng đối tượng ứng dụng phát
triển cho những loại ứng dụng (như ứng dụng Internet) mà không tuân theo những hỗ trợ
sẵn có truyền thống.
Người phát triển có thể tương tác với những lớp .NET Framework của Silverlight
bằng cách viết những mã (code) quản lý sử dụng ngôn ngữ C# hoặc Visual Basic. Người
phát triển .NET Framework cũng có thể truy xuất những lớp thể hiện thông qua Visual
Studio 2008 hoặc Microsoft Expression Blend.
Việc thêm vào chương trình Silverlight những tính năng giúp cho người phát triển
tạo được sự đa dạng và phong phú cho ứng dụng. Bao gồm những tính năng mô tả trong
bảng sau:
Tính năng Miêu tả
Isolated storage
Cung cấp sự truy xuất an toàn từ máy trạm (Client) Silverlight tới
những tập tin cục bộ hệ thống. Cho phép lưu giữ cục bộ và tạm thời
những dữ liệu riêng của người dùng.
Asynchronous
programming
Một nền của người làm việc với những chuỗi chứa đựng những yêu
cầu lập trình bên ngoài trong khi ứng dụng không ràng buộc người sử
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 24
Nguyễn Anh Việt
Lưu Xuân Việt
dụng tương tác.
File
management
Cung cấp sự an toàn trong hộp thoại mở tập tin (file), không ràng buộc
quá trình tạo những tập tin upload an toàn.
HTML–
managed code
interaction
Cho phép người lập trình .NET Framework trực tiếp thao tác trên phần
tử UI trong HTML DOM của trang Web. Người lập trình Web cũng có
thể sử dụng JavaScript để gọi trực tiếp những code quản lý bên trong
và truy xuất đối tượng scriptable, thuộc tính (properties), Sự kiện
(events), và phương thức (methods).
Serialization Cung cấp sự hỗ trợ đa dạng của kiểu CLR với JSON và XML.
Packaging
Cung cấp những lớp ứng dụng và xây dựng công cụ tạo những gói
.xap. Những gói .xap chứa đựng ứng dụng và những điểm tiếp nhận
điều khiển (control) việc chạy của Silverlight plug-in.
XML libraries
Những lớp XmlReader và XmlWriter đơn giản hóa việc làm việc với
dữ liệu XML từ những dịch vụ Web (Web services). Tính năng Xlinq
cho phép người lập trình truy vấn dữ liệu trực tiếp bên trong ngôn ngữ
lập trình .NET Framework.
4. Hỗ trợ những hệ điều hành và trình duyệt.
Bởi vì Silverlight là một ứng dụng nền đa nhiệm, chúng chạy trên hầu hết những
trình duyệt Web hiện hành.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
Hình 4: Bảng mô tả tính tương thích của hệ điều hành và trình duyệt
(Nguồn )
IV. MÔ HÌNH ỨNG DỤNG VÀ LẬP TRÌNH
Mục tiêu của Silverlight 2 đối với hầu hết các ứng dụng là viết code quản lý sử
dụng những ứng dụng mới nhất trong Silverlight. Bên cạnh đó, bạn có thể sử dụng những
tùy chọn để làm đơn giản hóa thay cho những mẫu lập trình.
Silverlight cung cấp 2 kiểu lập trình riêng biệt trong việc xây dựng những ứng
dụng:
SVTH: Thân Hoàng Lộc Trang 25
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 26
Nguyễn Anh Việt
Lưu Xuân Việt
- Quản lý API với Silverlight. Mục đích nhằm biên dịch và chạy code trên CLR
(common language runtime) hoặc trên DLR (dynamic language runtime) đối với
Silverlight.
- JavaScript với Silverlight. Thể hiện lên trình duyệt sử dụng code JavaScript.
Những mô hình lập trình này hoàn toàn khác biệt bởi vì chúng ta không thể đồng
thời sử dụng cả hai kiểu lập trình trên đối với một trường hợp cụ thể trong một Silverlight
plug-in. Tuy nhiên, bạn cũng có thể thi hành việc trang trí màn hình nền bằng cách sử
dụng một đoạn code JavaScript khi chuyển trạng thái qua managed API trong lúc tải ứng
dụng lên.
The managed API cung cấp nhiều hàm xử lý hơn JavaScript API, và đây là một
điểm nổi bật của Silverlight. Những ứng dụng sử dụng managed API truy xuất tới những
phiên bản .NET Framework nhẹ hơn. Còn đối với JavaScript API chỉ truy xuất và thể hiện
nội dung của Silverlight và những đoạn JavaScript nhúng vào trình duyệt.
1. Lập trình quản lý và mô hình ứng dụng (Managed Programming and the
Application Model)
Managed API cho phép bạn gói những trình điều khiển và những tập tin tài nguyên
vào trong một gói tập tin ứng dụng (.xap). Silverlight plug-in có nhiệm vụ tải những gói
ứng dụng này lên và rút trích nội dung bên trong.
Một gói ứng dụng chỉ chứa một nhóm hành động với những lớp đã được khai báo
trên ứng dụng. Lớp ứng dụng gói gọn sự tương tác giữa ứng dụng và Silverlight plug-in.
Chẳng hạn như, nó cho phép bạn trình bày một giao diện người dùng tương tác với trang
web chủ. Thêm vào đó, nó cung cấp những event của ứng dụng thường trực và quản lý tài
nguyên.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 27
Nguyễn Anh Việt
Lưu Xuân Việt
Điểm mạnh của Silverlight là sử dụng những mô hình ứng dụng giới hạn đề cập tới
những gói ứng dụng và những hàm đã được đóng gói bởi những lớp Application. Mô hình
ứng dụng giúp chúng ta trình bày được cả những ứng dụng đơn giản và phức tạp. Có thể
mở rộng ứng dụng này bằng cách chia sẻ những tài nguyên trên mạng.
A. Managed API for Silverlight
Bạn có thể sử dụng ngôn ngữ đánh dấu XAML gói gọn những giao diện người
dùng đã thiết kế vào trong managed API và JavaScript API. Với managed API, bạn có thể
đưa thừa số code ứng dụng vào nhiều tập tin (File) và cung cấp thêm code-behind kèm
theo.
Khi Silverlight plug-in tải những những tập tin XAML lên, nó sẽ tạo ra một cây
đối tượng mà những mã bên trong (code-Behind) có thể thao tác. Những mã quản lý ứng
dụng cũng có thể được thao tác bởi HTML DOM (Document Object Model) thông qua
cầu nối HTML.
Silverlight API định nghĩa việc thiết lập đối tượng y như là một cây đối tượng mà
cho phép bạn chứa đựng nội dung khởi tạo ban đầu của ứng dụng nền Silverlight được tải
lên bởi XAML, và điều chỉnh cây đối tượng này trong thời gian thực thi. Bên trong
managed API, sự tương tác với cây đối tượng Silverlight là định nghĩa với managed code.
Sử dụng CLR, managed code là sự biên dịch vào bên trong assembly. Assembly tiêu biểu
cũng chứa đựng XAML cho ứng dụng nền Silverlight. Managed code có thể Support cho
mô hình ứng dụng Silverlight, và có thể gọi hồi đáp của đối tượng trong suốt thời gian
sống của những event, hoặc là những event khởi tạo user. Bạn cũng có thể sử dụng
managed code để viết những lớp hỗ trợ, định nghĩa những đối tượng data, và cho nhiều
những kịch bản ứng dụng khác. Bạn cũng có thể sử dụng DLR nhiều hơn CLR, vấn đề
này đang được tranh luận trong Dynamic Languages in Silverlight 2.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 28
Nguyễn Anh Việt
Lưu Xuân Việt
¾ Đặc điểm của Managed API (Characteristics of the Managed API)
a. Managed Code là sự mở rộng
Trong Silverlight 1.0 trước đây, và bên dưới JavaScript API hiện tại (độc lập với
version client) không hỗ trợ cho việc khai báo hạn chế một tùy chọn phần tử UI. Bạn có
thể kết hợp một phần tử và khi tải chúng mất nhiều thời gian từ khai báo tương tự của
XAML, và gán những hàm tương tự như code hỗ trợ. Nhưng điều này gần như không hỗ
trợ cho việc co giãn, phóng to kích thước. Sử dụng Managed API, tính co dãn hoàn toàn
là một vấn đề xuất phát từ những lớp hoặc control hiện hành được hỗ trợ một cách hữu
ích trong những hàm xử lý cơ bản. Và cũng có thể khai báo bằng một số phần tử hỗ trợ
như: tạo mới một control template, cập nhật những lớp event handle…v…v…Mở rộng
việc quản lý code cũng là khái niệm cơ bản của việc quản lý và lập trình .NET
Framework và đây cũng không phải là một vấn đề đơn giản trong Silverlight.
b. Cây đối tượng (Object Trees)
Cây đối tượng là khái niệm tồn tại trong JavaScript API, và sự vận dụng cây vào
trong mô hình này cũng có giới hạn bởi vì nó không có một đối tượng kỹ thuật khởi tạo.
Trong quản lý API, bạn có thể gọi hàm khởi tạo bên trong những lớp và có thể thêm vào
cây mà không cần sử dụng phân tích XAML làm trung gian. Thật ra, bạn có thể xây dựng
một cây thật quy mô hoàn toàn trong khai báo code bằng cách gọi sự khởi tạo liên tục và
thêm những đối tượng vào cây đối tượng bắt đầu từ root và xuyên suốt trong các thuộc
tính con (Children).
Bạn có thể tham chiếu các đối tượng trong cây đối tượng suốt thời gian thực thi
của Silverlight bằng cách quản lý code hoặc JavaScript.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 29
Nguyễn Anh Việt
Lưu Xuân Việt
c. Quản lý code-behind và các lớp cục bộ (Managed Code-Behind and Partial
Classes)
Kỹ thuật chính trong việc khai báo một UI trong Silverlight là việc định nghĩa các
phần tử trong việc tạo XAML. Điều này gồm cả việc sử dụng những Style và Template,
chúng cũng được khai báo bên trong việc tao XAML. Trong nhiều trường hợp bạn sẽ
muốn đưa những đối số khác nhau vào trong những file XAML mà được tích hợp trong
những mô hình ứng dụng Silverlight. Để định nghĩa một tương tác cần thiết trong ứng
dụng, bạn thường muốn định nghĩa event handler mà đáp lại tới đối tượng trong suốt thời
gian event sống hoặc event khởi tạo user cho những đối tượng được khai báo trong
XAML. Trong quản lý API, mỗi trang XAML là nơi chứa đựng những event handling
hoặc nội dung của những phần tử root. Chúng chỉ được đưa vào quá trình thực thi như là
một phần tất yếu của quá trình xây dựng. Sự đưa vào quá trình thực thi này cung cấp
những móc nối cần thiết trong suốt thời gian chạy tương tác với cây đối tượng được tạo ra
khi trang XAML tải lên. Những móc-nối này bao gồm những event handler tốt nhất tham
chiếu tới bất kỳ đối tượng nào được đặt Name hoặc x:Name trong XAML. Trong cấu trúc
Silverlight, XAML không biên dịch hết nội dung bên trong nó. Nhiều cây đối tượng được
tạo ra trong XAML cho UI bị trì hoãn lại cho tới khi trang XAML thực sự được tải lên hết
trong ứng dụng đang chạy và được xử lý bằng những đoạn XAML Silverlight.
Code-Behind là một thuật ngữ sử dụng miêu tả code tham gia vào một lớp thành
phần với trang XAML khi tạo dựng hoặc biên dịch ứng dụng.
d. Chuẩn hóa tương tác DOM (Formalized DOM Interaction)
Trong JavaScript API, tham chiếu đối tượng hoặc biến trong HTML DOM từ
Silverlight nguyên bản hoặc ngược lại không có liên quan gì bởi vì chính nó đã có thể
trình bày được bởi sự tồn tại của nó trong trình duyệt hoặc trong một phạm vi nào đó.
Trong code quản lý API, một phân đoạn định dạng đã tồn tại bởi vì code quản lý sử dụng
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 30
Nguyễn Anh Việt
Lưu Xuân Việt
thư viện trong Silverlight và chính CLR chứ không phải là trình duyệt. Sự tương tác với
DOM từ quản lý API, bạn có thể sử dụng một chuỗi những đặc trưng mà đôi khi những
tập chuỗi này được tham chiếu như là một cầu nối HTML, hoặc cầu nối HTML DOM.
Bao gồm những phần sau:
• APIs đưa ra những nhiệm vụ xử dụng DOM phổ biến (trong những trường hợp, tài
liệu đối tượng) để code quản lý.
• Điều kiện dễ dàng có thể tạo những kiểu quản lý chính từ DOM.
• Kỹ thuật chuyển đổi những kiểu quản lý phát sinh từ những giá trị hoặc đối tượng
chính JavaScript.
• APIs đưa ra những nét đặc trưng của đối tượng Silverlight plug-in trình bày trong
DOM.
B. JavaScript API for Silverlight
JavaScript API là một mô hình đã được tích hợp sẵn trong bản Silverlight 1.0, và
nó vẫn giữ được tính tương thích cũng như chạy những kịch bản ngoại lệ.
Trong JavaScript API, Silverlight plug-in tải lên một trang XAML đơn thay vì một
gói ứng dụng. Trang XAML có thể bao gồm URL tham vấn tới một tài nguyên bên ngoài
máy chủ (Server), như là hình ảnh và Video. Silverlight plug-in sử dụng XAML để tạo
nên một cây đối tượng mà chúng ta có thể vận dụng nhiều cách lập trình sử dụng
JavaScript trong tranh HTML chính.
JavaScript không cung cấp một mô hình ứng dụng riêng nhưng nó hỗ trợ với sự
điều hướng trong nội dung ứng dụng để giải quyết những vấn đề phức tạp. Bên cạnh đó,
nó cũng có thể giải quyết những kịch bản “cồng kềnh” như trong managed API ví dụ như
trang trí màn hình nền (splash screens). Bạn cũng có thể tải lên những trang XAML mới
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 31
Nguyễn Anh Việt
Lưu Xuân Việt
trong Silverlight plug-in hoặc những trang web mới trong trình duyệt và định hướng thực
thi ban đầu cho chúng.
Trong một vài trường hợp, JavaScript API với Silverlight phụ thuộc vào nhau nhiều hơn
so với Code quản lý.
1. Cân nhắc kiểu lập trình (Programming Model Considerations)
JavaScript API với Silverlight là kiểu lập trình mà đã được tích hợp sẵn trong
phiên bản 1.0 của Silverlight. Nó sử dụng những tập con nhỏ của đối tượng mà sẵn sàng
dùng được trong Silverlight 2, cộng với một số đối tượng riêng biệt trong JavaScript API.
Tập con này cũng cân nhắc sự ảnh hưởng với những đối tượng mà bạn khai báo
trong XAML. Phân tách XAML của Silverlight chỉ tạo nên đối tượng bên trong cây đối
tượng của những tập con này. Bởi vì cây đối tượng được tạo nên trên nền code cố định thi
hành những cái bên dưới JavaScript. Nói cách khác, tập con và sự cân nhắc giới hạn mà
áp dụng với JavaScript API cho Silverlight là sự có thật nhiều hơn ngôn ngữ mà bạn lựa
chọn để viết cho chuỗi lý luận bên trong code-behind; Lựa chọn lập trình kiểu API cho
phép bạn xác định rõ những đối tượng nào sẵn dùng trong ứng dụng.
Nếu bạn đã phát triển trong Silverlight 1.0, chắc chắn bạn đã quen thuộc với
JavaScript API trong Silverlight. Lập trình JavaScript API tương tự như trong HTML
DOM, và thực ra là sự thi hành những kịch bản nhúng trong trình duyệt giống như là kịch
bản trong DOM. Nhưng mô hình Silverlight mở rộng trong cây đối tượng mà được tạo
nên khi một trang XAML tải lên những nội dung co Silverlight plug-in. Điều này cho
phép bạn xử lý những event trên đối tượng tiêu biểu mà bạn đã định nghĩa trong XAML.
Get hoặc set giá trị thuộc tính hoặc thi hành những phương thức đối tượng trong thời gian
chạy, chỉnh sửa cấu trúc của XAML, tạo cây đối tượng trong thời gian chạy và…v.v…
Trong điều kiện của cấu trúc, JavaScript API cho phép một hướng mở trong cây
đối tượng Silverlight trên Silverlight plug-in, bao bọc những kịch bản được triệu gọi, và
kết thúc chúng trong plug-in như những đối tượng tự nhiên. Trong Internet Explorer việc
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 32
Nguyễn Anh Việt
Lưu Xuân Việt
bao bọc được thực hiện khi gọi IDispatch::Invoke. Còn trong những trình duyệt khác có
khả năng sử dụng những kiểu bao bọc khác phụ thuộc vào những plug-in và cấu trúc kịch
bản.
2. Kịch bản cho khai báo JavaScript API (Scenarios for Using the JavaScript API)
¾ Splash Screens
Một Splash Screens là nội dung một khu vực khởi tạo để trình bày tới user trong khi
những nội dung khác vẫn tiếp tục đang tải lên. Bên trong điều kiện thiết kế và mục đích,
một Splash Screens đã ngầm quan hệ với UI và những yêu cầu tương tác. Mục đích chính
của Splash Screens là:
• Thể hiện tính trực quan thú vị.
• Cung cấp thông tin phản hồi tới user mà ứng dụng (hoặc brower host) vẫn còn
những hàm xử lý như mong đợi và tải chúng về như là sự phát triển.
• Giữ những thông tin đặc trưng trong tiến trình tải về.
Hai hàm đầu tiên có đủ tính năng thường thấy trong XAML mà không cần code-
behind bên trong. Miễn là tiến trình tải về yêu cầu thu được những thông tin tối thiểu của
một API từ lớp mạng mà nó thực hiện việc tải về. Có những lý do một Splash Screens là
phương tiện tốt nhất bởi sự khai báo JavaScript API và truyền tải một trang XAML (Được
hỗ trợ bởi Script code Behind) cho SplashScreenSource. JavaScript API có thể tải về
Splash Screen mà không cần tác động tới Silverlight CLR và liên quan tới assemblies để
rút ngắn thời gian khởi động.
3. Phiên bản JavaScript mới cho Silverlight 2 (New JavaScript API for Silverlight
Version 2)
Silverlight 2 cung cấp việc thêm vào những đối tượng có thể sử dụng trong JavaScript
API khác với việc thiết lập những đối tượng trong Silverlight 1.0. Nó hoàn toàn cho phép
bởi vì những đối tượng này có sự thi hành tự nhiên mà nó trình bày tương tự như việc
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 33
Nguyễn Anh Việt
Lưu Xuân Việt
khởi tạo một đối tượng trong bản 1.0. Bạn có thể tạo những đối tượng này trong bên trong
XAML và sau đó script đến cây đối tượng. Để sử dụng những đối tượng này, client chạy
những ứng dụng nền Silverlight nên có bản chạy Silverlight version 2 client.
Việc thêm vào những đối tượng với JavaScript API là bao gồm bên trong những tư
liệu Silverlight cho JavaScript (Như thuộc tính-Properties, phương thức-Method, event,
và bảng liệt kê- enumerations). Đây là những tài liệu cấp cơ bản. Đối tượng mới và thành
viên mới cần chú ý tới những thông tin của phiên bản tham khảo trong trang chủ.
4. Những kỹ thuật riêng của JavaScript API (Technical Specifics of the JavaScript
API)
Có một vài kỹ thuật riêng trong JavaScript API khác với việc quản lý API và sự mở
rộng sang nhiều những phần tử JavaScript API
- JavaScript và các trường hợp nhạy cảm (JavaScript and Case Sensitivity)
Các đối tượng, phương thức và tên thuộc tính trong JavaScript là không được xem xét
như là trường hợp nhạy cảm khi được xử lý bởi Idispatch hoặc kỹ thuật song song mà là
bên ngoài Silverlight JavaScript API tới tập lệnh nhúng vào trong Brower Hosting. Vì
vậy, bạn có thể dùng chữ hoa để khởi tạo trong giá trị thuộc tính event XAML và chữ
thường trong những phương thức được định nghĩa hiện tại nếu bạn thích. Tuy nhiên, tài
liệu cú pháp Silverlight và những tiêu đề trong những text mô tả chung phải chuẩn hóa
những trường hợp cho đối tượng-object, thuộc tính-properties, phương thức-method,
events, bảng liệt kê- enumerations, và các giá trị liệt kê ban đầu sử dụng chữ hoa tốt hơn
là sử dụng chữ hoa bên trong. Có hai lý do:
• XAML rất nhạy cảm trong việc phân biệt chữ, bởi vì nó theo chuẩn XML. Cú
pháp XAML và những tập lệnh tương đương thường có mặt trong một trang
đơn. Vì vậy, nó cần một chuẩn hóa trong XAML. Titling mà bạn thấy trong tài
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 34
Nguyễn Anh Việt
Lưu Xuân Việt
liệu Silverlight là những biểu mẫu trường hợp chính xác cho một phần tử đối
tượng hoặc thuộc tính XAML.
• Quản lý API xử lý tất cả các trường hợp như là trường hợp nhạy cảm, khai báo
như trong quy ước Pascal. Hiện tại JavaScript tham chiếu trường hợp tương
đương ở mức cao hơn không cần đường dẫn.
C. JavaScript và HTML DOM
JavaScript API và managed API đều cho phép bạn sử dụng JavaScript trong trang
HTML chính tích hợp Silverlight với HTML DOM (Document Object Model).
Trong JavaScript API, bạn chỉ thực thi những hàm ứng dụng sử dụng trong trình
duyệt mà JavaScript đã khai báo. Chúng cũng có thể tương tác trực tiếp với DOM. Trong
managed API, những mã JavaScript và DOM tương tác với Silverlight plug-in và mô hình
ứng dụng sử dụng cầu nối HTML.
1. Cấu trúc ứng dụng (Application Structure)
Khi bạn tạo một ứng dụng nền Silverlight sử dụng managed API, tiến trình xử lý sẽ
sinh ra một gói ứng dụng. Gói ứng dụng được nén lại trong tập tin có phần mở rộng là
.xap và nó chứa đựng những tập tin cần thiết để bắt đầu một ứng dụng.
Khi nhúng Silverlight plug-in vào trang Web, bạn có thể chỉ định rõ những gói ứng
dụng nào mà Plug-in cần tải về. Plug-in sử dụng một tập tin hiển thị trong gói ứng dụng
để nhận dạng những lớp ứng dụng đã được triệu gọi. Những lớp này được biết đến như là
một điểm mục (entry) của ứng dụng và nó chỉ bắt nguồn từ những lớp Application. Đối
với những ứng dụng riêng lẻ, plug-in cũng sẽ triệu gọi những tập xử lý (essemble) căn
bản chi tiết mà nó thừa hưởng.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 35
Nguyễn Anh Việt
Lưu Xuân Việt
Lớp Application cung cấp một sự kiện bắt đầu (Startup event) để bạn có thể khởi
tạo những handle ban đầu cho ứng dụng và giao diện người dùng. Lớp Application cũng
cung cấp những yêu cầu dịch vụ ứng dụng phổ biến khác. Ví dụ bạn có thể sử dụng lớp
Application để rút trích những tập tin tài nguyên từ những gói ứng dụng hoặc tải về từ
những tập tin zip.
Quá trình tải về (download) một gói ứng dụng và ngay lập tức gọi hệ thống kích
hoạt Silverlight. Hệ thống kích hoạt cho phép bạn chỉ định giá trị nhỏ nhất của gói tải về.
Sau khi kích hoạt, ứng dụng của bạn có thể truy xuất tới những tập xử lý (assemble) đã
thêm vào trong thư viện và những tập tin tài nguyên theo yêu cầu.
2. Gói ứng dụng (Application Package)
Một gói ứng dụng bao gồm những tập tin:
- Một tập tin AppManifest.xaml, nó nhận dạng những bộ xử lý đã đóng gói và điểm
bắt đầu của ứng dụng.
- Một bộ xử lý ứng dụng, bao gồm những lớp ứng dụng.
- Không, hoặc nhiều thư viện những bộ xử lý.
- Không, hay nhiều tập tin tài nguyên không xác định, ví dụ như hình ảnh (image)
hoặc những tập tin Video.
Tập tin AppManifest.xaml là tập tin tự động sinh ra (generate) điển hình trong quá
trình xây dựng và sử dụng ngôn ngữ đánh dấu XAML để trình bày một đối tượng
Deployment với trình ứng dụng.
Trong tập tin AppManifest.xaml, phần tử Deployment bao gồm những thuộc tính:
- Thuộc tính RuntimeVersion nhận dạng phiên bản yêu cầu của Silverlight.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 36
Nguyễn Anh Việt
Lưu Xuân Việt
- Thuộc tính EntryPointType và EntryPointAssembly nhận dạng mục bắt đầu của
ứng dụng.
Phần tử Deployment cũng bao gồm một phần tử đặc tính con Deployment..::.Parts mà
có một phần tử con AssemblyPart riêng cho mỗi assembly trong một gói ứng dụng.
Gói ứng dụng chỉ bao gồm một tập tin AppManifest.xaml và một entry-point của
assembly ứng dụng. Bạn cũng có thể triển khai tất cả các thành phần ứng dụng khác trong
file đóng gói (in-package) hoặc trong file yêu cầu (on-demand).
Trong file đóng gói là những file được chứa đựng bên trong gói ứng dụng. Điển hình
là những file tối thiểu để bắt đầu ứng dụng hoặc triệu gọi những file sẵn sàng dùng đến
sau khi khởi động. Bạn cũng có thể chia sẻ những nguồn tài nguyên như hình ảnh nhúng
trực tiếp vào trong assembly hoặc những file riêng biệt trong phạm vi của gói ứng dụng.
Những file yêu cầu là những file mà bạn triển khai trên máy chủ (Server). Chẳng hạn
như vị trí của các gói ứng dụng. Ứng dụng của bạn có thể truy xuất những file này sau khi
chúng được kích hoạt. Độc lập về kích thước và thể loại file nên có thêm vài tùy chọn
trong việc truy xuất những file yêu cầu này. Ví dụ như bạn có thể sử dụng tham chiếu trực
tiếp URL để truy xuất những file hình ảnh (Image) hoặc bạn có thể đồng bộ sự bắt đầu
trong việc tải về hay truy xuất những thư viện assembly hoặc những file zip.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
Hình 5: Biểu đồ tổng hợp những gói cấu trúc ứng dụng và những tùy chọn triển khai trong
những file ứng dụng.
3. Triển khai file trong những gói hoặc trong những yêu cầu (Deploying Files In-
Package or On-Demand)
Việc triển khai những file ứng dụng bên trong những gói ứng dụng được diễn ra
trong thời gian khởi động và trong lúc tải về, chúng chỉ ngưng khi bạn quyết định ngừng
những tiến trình này lại. Quyết định này hoàn toàn độc lập với những yêu cầu của ứng
dụng. Chẳng hạn, bạn có thể cho phép khai báo nhiều file vào bên trong những gói ứng
dụng và lần lượt nhận được những hồi đáp sau khi bạn bắt đầu thực hiện (Startup). Trong
trường hợp này bạn có thể duy trì trạng thái hồi đáp hiển thị lên màn hình khi bắt đầu tiến
trình tải về.
SVTH: Thân Hoàng Lộc Trang 37
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 38
Nguyễn Anh Việt
Lưu Xuân Việt
Trong một vài trường hợp, Silverlight plug-in sẽ không thể tải lên những gói ứng
dụng lớn. Khi bạn khởi tạo những ứng dụng lớn, bạn nên triệu gọi những file cần thiết để
tối ưu hóa kích thước dữ liệu.
Khi bạn quyết định di chuyển một vài file ra ngoài gói ứng dụng, bạn nên bố trí lại
một vài tùy chọn.
Những file dễ dàng bố trí lại là những file tham chiếu (reference) trong khai báo
quan hệ URIs ví dụ như những file video và image. Khi Silverlight plug-in bắt gặp một
quan hệ URL trong code hoặc XAML nó sẽ được nhìn thấy trong gói ứng dụng đầu tiên.
Nếu plug-in không thể tìm thấy file trong gói ứng dụng thì nó sẽ thấy được bên trên máy
chủ. Nghĩa là bạn có thể di chuyển bất kỳ file nào mà bạn tham chiếu bởi quan hệ URL
mà không cần phải thay đổi code.
Nhiều file không thể tham chiếu bằng URL và nó phụ thuộc vào những tiến trình
xử lý riêng nếu bạn bố trí lại những file yêu cầu này. Ví dụ như, bạn muốn bố trí lại thư
viện assembly, bạn nên thêm code để triệu gọi những yêu cầu và tải chúng lên vùng ứng
dụng.
Bạn cũng có thể muốn di chuyển một vài file tài nguyên ra ngoài những gói ứng
dụng nhưng truy xuất chúng trong yêu cầu như là tải 1 trình đơn về. Bạn cũng có thể thực
hiện những điều trên bằng cách gói chúng lại thành những file zip và triển khai chúng lại
trên máy chủ.
V. ỨNG DỤNG DỊCH VỤ (Application Services)
Khi bạn tạo một ứng dụng sử dụng managed API với Silverlight, bạn nên tạo một
lớp mà bắt nguồn từ Application. Lớp Application cung cấp một vài dịch vụ mà những
ứng dụng thường cần tới. Trước hết, nó miêu tả những entry point của code ứng dụng
trong suốt chu trình sống của Silverlight plug-in.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
Chu trình sống của Silverlight plug-in bắt đầu khi user “lướt” vào trang web chứa
Silverlight plug-in. Nếu user đã cài đặt Silverlight, trình duyệt web sẽ kích hoạt plug-in và
bắt đầu tải những gói ứng dụng của bạn xuống.
Plug-in được nạp vào trong theo dịch vụ của Silverlight bởi Silverlight CLR,
chúng tạo ra một AppDomain cho ứng dụng. Khi những gói ứng dụng của bạn hoàn tất
việc tải về, CLR sẽ triệu gọi lớp Application và sinh ra những event Startup.
Bạn có thể thêm code vào những lớp ứng dụng. Bên cạnh đó,bạn sử dụng một
event handle startup cho hầu hết những yêu cầu khởi tạo ứng dụng, như trình bày một
trang giao diện người dùng.
Hình 6: Biểu đồ minh họa quy trình kích hoạt plug-in và mối quan hệ giữa các thành phần
trong quy trình
SVTH: Thân Hoàng Lộc Trang 39
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 40
Nguyễn Anh Việt
Lưu Xuân Việt
Chúng cũng có thể chỉ là một trường hợp Application trong ứng dụng nền
Silverlight. Sau khi khởi động (Startup), trường hợp Application này cung cấp một vài
dịch vụ mà ứng dụng thường cần tới. bạn có thể truy xuất những dịch vụ này từ bất kỳ
đoạn code nào trong ứng dụng bởi sự truy xuất trường hợp Application từ đặc tính tĩnh
của Application..::.Current.
Những đặc trưng trong lớp Application gồm:
• Quản lý thời gian sống của ứng dụng.
• Tải lên những file tài nguyên của ứng dụng.
• Xử lý những ngoại lệ Unhandled.
• Tích hợp những Web host.
1. Application Lifetime Management
Để quản lý thời gian sống của ứng dụng bạn có thể thêm code vào trong những lớp
ứng dụng để chạy và bắt điểm thời gian sống của ứng dụng:
• Lớp khởi tạo ứng dụng.
• Event Startup ứng dụng.
• Event Exit ứng dụng.
a. Lớp khởi tạo ứng dụng (Application Class Construction)
Trong lớp ứng dụng khởi tạo, bạn có thể thêm code vào trong lớp ứng dụng khởi
tạo để thi hành những yêu cầu khởi tạo cơ bản, chẳng hạn như những biến khởi tạo và
những event handler kèm theo.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 41
Nguyễn Anh Việt
Lưu Xuân Việt
Hầu hết những lớp ứng dụng được định nghĩa đều sử dụng ngôn ngữ đánh dấu
XAML và một file code-behind. Việc xây dựng những lớp ứng dụng tiêu biểu này bao
gồm việc triệu gọi một phương thức InitializeComponent để hồi đáp trong việc kết hợp
XAML với những file code-behind. Quá trình xây dựng sinh ra và thực thi một phương
thức InitializeComponent để nạp lên XAML bởi việc triệu gọi phương thức
Application.LoadComponent.
Ứng dụng XAML có thể chỉ định event handle ứng dụng và sẽ cư trú trong thư
mục Application.Resources với thuộc tính và kiểu dáng sử dụng trong toàn thể ứng dụng.
b. Application Startup
Event Application.Startup xuất hiện khi Silverlight plug-in kết thúc quá trình tải
những gói ứng dụng lên. Tại thời điểm này, tất cả bên trong các gói assemblies đã được
tải lên bên trong vùng ứng dụng và sẵn sàng sử dụng.
Bạn có thể sử dụng event Startup để thi hành những yêu cầu khởi tạo phổ biến như:
• Xử lý dữ liệu được gọi trong quá trình khởi động, như khởi tạo và tham số URL
hoặc lưu dữ liệu vào trong những phiên làm việc trước.
• Trình bày giao diện người dùng (UI).
• Bắt đầu không đồng bộ việc tải xuống khi thêm vào những file tài nguyên hoặc
assemblies.
Sau đây là mô tả ngắn gọn cách thực hiện các yêu cầu và cung ca61op những Link
thông tin:
c. Processing Startup Data
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 42
Nguyễn Anh Việt
Lưu Xuân Việt
Để truy xuất những tham số khởi tạo ban đầu trong việc cấu hình Silverlight plug-
in, cần sử dụng thuộc tính StartupEventArgs.InitParams.
Khi truy xuất tham số URL từ trang web chủ, cần sử dụng thuộc tính
HtmlDocument.QueryString. Bạn có thể truy xuất đối tượng HtmlDocument từ thuộc tính
tĩnh HtmlPage.Document. Nhưng cần chú ý thuộc tính Document có thể không sử dụng
được nếu việc truy xuất HTML thất bại. Đây cũng là một trường hợp điển hình khi gọi
một ứng dụng nền Silverlight trong trang web chủ từ một vùng (Domain) khác.
Để truy xuất dữ liệu từ những phiên làm việc trước, ta sử dụng lớp
IsolatedStorageSettings.
Để khởi tạo data luôn sẵn sàng tương tác trong ứng dụng, cần thêm vào thư mục
Application.Resources.
d. Displaying the User Interface
Để hiển thị UI ứng dụng, cần set thuộc tính RootVisual trong event handler
Startup.
Bạn chỉ có thể set thuộc tính này ở lần đầu tiên, nhất là ở UserControl cung cấp
một Layout Root cho UI. Bạn có thể thay đổi UI của mình sau khi khởi tạo bằng cách
thay đổi nội dung của Layout root.
Chú ý:
Event Startup có thể xuất hiện trước khi trang web chủ tính toán việc sắp đặt
layout. Nếu bạn sử dụng những quan hệ kích thước trong Silverlight plug-in, giá trị
Content.ActualHeight và ActualWidth sẽ không có ý nghĩa trong ứng dụng khởi tạo. Để
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 43
Nguyễn Anh Việt
Lưu Xuân Việt
co giãn UI hoặc thi hành những layout nền trong kích thước hiện tại của plug-in, bạn có
thể sử dụng handle Content.Resized event.
e. Truy xuất những tài nguyên thêm vào (Retrieving Additional Resources)
Để đồng bộ những file tài nguyên hoặc assemblies thêm vào, ta sử dụng lớp
WebClient.
Nếu là file zip, bạn cần phải sử dung phương thức
Application.GetResourceStream(StreamResourceInfo, Uri) để rút trích những nội dung
bên trong sau khi tải về.
Nếu là file trong assembly, bạn có thể tải chúng vào trong ứng dụng AppDomain
bằng cách tạo mới một đối tượng AssemblyPart và gọi phương thức Load.
f. Application Exit
Event Application.Exit xuất hiện khi một hành động tiếp diễn đưa ra yêu cầu:
• User đóng trang web chính Silverlight plug-in.
• User refreshes trang web chính.
• User lướt trình duyệt từ trang web chính.
• Trang web chính sử dụng JavaScript và HTML DOM gỡ bỏ plug-in trong trang
web.
• User logs off hoặc shuts down hệ điều hành.
Một cách phổ biến trong việc sử dụng Event Application.Exit là việc sử dụng lớp
IsolatedStorageSettings để lưu lại việc bố trí các ứng dụng.
2. Application Resource File Loading
Silverlight có khả năng cung cấp rộng lớn đối với việc tải lên những file tài nguyên từ
một ứng dụng assembly, một thư viện assembly, một gói ứng dụng và một host server.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 44
Nguyễn Anh Việt
Lưu Xuân Việt
Những sự hỗ trợ này phụ thuộc và việc bạn định cấu hình cho những file tài nguyên, triển
khai chúng ở đâu và tải chúng lên như thế nào.
Lập trình truy xuất những file tài nguyên thô sử dụng phương thức
Application..::.GetResourceStream. Phương thức này quy định dung lượng cho phép rút
trích những file tài nguyên từ gói ứng dụng hoặc từ file zip mà bạn truy xuất theo yêu cầu.
3. Xử lý những ngoại lệ Unhandled (Unhandled Exception Processing)
Trong suốt thời gian sống của ứng dụng, có những trạng thái mà không thể lường
trước được xuất hiện mà nguyên nhân đó Silverlight plug-in đưa vào những ngoại lệ. Mặc
dù bạn có thể bắt được những ngoại lệ đó trong code ứng dụng, nhưng cũng không thể bắt
được hết những ngoại lệ tiềm tàng.
Ngoại lệ Unhandled sẽ là nguyên nhân Silverlight plug-in dừng tiến trình chạy trong
trình duyệt. Event handle Application..::.UnhandledException sinh ra việc ngăn cản này.
Bạn có thể sử dụng event data để xác định xem ngoại lệ này có thể cứu chữa hay
không.Nếu có thể, hãy đặt thuộc tính
ApplicationUnhandledExceptionEventArgs..::.Handled là true.
Nếu bạn không xử lý ngoại lệ này trong code quản lý, Silverlight plug-in sẽ xuất hiện
event onError. Nó sẽ đưa cho bạn một cơ hội kết thúc xử lý ngoại lệ bằng cách sử dụng
JavaScript trong trang web chính. Event onError đưa ra lỗi code truy xuất plug-in, điều
này rất hữu ích trong việc debug.
4. Host Integration
Điều này thỉnh thoảng hữu ích cho code quản lý tương tác trực tiếp với Silverlight
plug-in trên host. Chẳng hạn như, bạn có thể muốn truy xuất giá trị cấu hình ban đầu của
plug-in, hoặc cho phép user xem plug-in ở chế độ full-screen.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
Việc truy xuất một đối tượng được miêu tả trong host plug-in hiện hành ta sử dụng
thuộc tính Application..::.Host. Thuộc tính này trả về một trường hợp của lớp
SilverlightHost, mà cung cấp hàm xử lý song song những tính năng mô tả trong
Silverlight Plug-in Object Reference.
VI. MỘT SỐ VÍ DỤ VỀ SILVERLIGHT
Ví dụ đầu tiên cho lập trình ứng dụng Silverlight.
Chúng ta sẽ bắt đầu xây dựng chương trình Digg bằng cách chọn File->New trong
VS2008 và dùng hộp thoại New Project để tạo một ứng dụng "Silverlight Application"
(nhớ rằng bạn đã tải về và cài đặt Silverlight Tools for VS 2008 thì mới có mục này)
Chúng ta sẽ đặt tên cho dự án này là "DiggSample". Khi nhấn vào nút OK, Visual
Studio sẽ mở một hộp thoại nữa cho phép lựa chọn việc tạo chỉ một ứng dụng Silverlight,
hay tạo thêm cả một ứng dụng ASP.NET vào Solution để chứa ứng dụng Silverlight bên
SVTH: Thân Hoàng Lộc Trang 45
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
trong. Với ứng dụng này, chúng ta sẽ chọn để thêm một ứng dụng ASP.NET và đặt tên
cho nó là "DiggSample_WebServer". Khi chúng ta nhấn OK, VS sẽ tạo một solution chứa
cả hai ứng dụng Silverlight và ASP.NET.
Khi thực hiện lệnh build, VS sẽ tự động sao chép ứng dụng Silverlight sang ứng
dụng web của chúng ta. Ứng dụng web được tạo sẵn này sẽ có cả các trang ASP.NET và
các trang HTML tĩnh, và chúng ta có thể dùng các trang này để test ứng dụng Silverlight.
Ghi chú: Các ứng dụng Silverlight có thể được dùng bên trong bất kỳ web server nào
(bao gồm cả Apache trên Linux) và được chứa bên trong các trang HTML tĩnh hay bất kỳ
dạng trang web động nào (bao gồm cả PHP, Java, Ruby, Python...). Với ứng dụng Digg,
chúng ta sẽ không dùng mã server-side nào, chúng ta sẽ dùng tính năng "cross-domain
networking" của Silverlight để truy cập tập hàm của dịch vụ Digg một cách trực tiếp. Sở
dĩ tôi tạo cả ứng dụng ASP.NET là vì muốn tận dụng tính năng triển khai tự động và dùng
thử nó trong web server có sẵn khi phát triển ứng dụng ASP.NET với VS.
- Có gì trong một ứng dụng Silverlight
SVTH: Thân Hoàng Lộc Trang 46
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
Mặc nhiên, một ứng dụng Silverlight mới được tạo sẽ chứa hai file có tên
Page.xaml và App.xaml, cũng như các file code behind tương ứng (được viết bằng VB,
C#, Ruby hoặc Python).
Các file XAML là các file ở dạng văn bản mà bạn dùng để khai báo các thành phần
giao diện trong một ứng dụng Silverlight hay WPF. XAML cũng có thể được dùng cả
trong việc khai báo các đối tượng .NET.
File App.xaml được dùng để khai báo các tài nguyên, kiểu như các đối tượng brush
hay style mà sẽ được dùng trong suốt toàn bộ ứng dụng. Lớp Application (code-behind
của file App.xaml) có thể được dùng để xử lý các sự kiện ở cấp độ ứng dụng, như
Application_Startup, Application_Exit và Application_UnhandledException.
File Page.xaml mặc nhiên được dùng như thành phần giao diện mà nó sẽ được hiển thị
khi ứng dụng được kích hoạt. Chúng ta có thể định nghĩa giao diện bên trong nó, và
chúng ta cũng có thể xử lý các sự kiện gây ra bởi các thành phần giao diện này bên trong
lớp code-behind của file Page.xaml.
Khi chúng ta build ứng dụng DiggSample, Visual Studio sẽ mặc nhiên biên dịch
các lệnh và các thẻ XAML vào một file assembly .NET, rồi đóng gói nó cùng với các tài
nguyên tĩnh (như các file hình ảnh hay văn bản mà chúng ta muốn đóng gói cùng) vào
SVTH: Thân Hoàng Lộc Trang 47
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
một file có tên DiggSample.xap:
Các file ".xap" (đọc là zap) dùng thuật toán nén zip để tối thiểu hóa kích thước file.
Một ứng dụng "Hello world" được viết trong .NET Silverlight (dùng VB hay C#) chỉ có
kích thước 4KB.
Ghi chú: Một số control trong bản Beta1 nếu được dùng sẽ phải được đóng góp kèm với
ứng dụng, do vậy có thể sẽ làm tăng kích thước của file .xap. Chương trình Diggchỉ dùng
các control trong bản Beta2 và phiên bản chính thức, do vậy kích thước tổng cộng sẽ chỉ
khoảng 6-8KB.
Để chạy một file Silverlight 2, bạn sẽ phải thêm thẻvào trong một file HTML
(không cần dùng Javascript> Silverlight sẽ tự động download file .xap, khởi tạo nó và
chạy nó trên nền của trình duyệt. Điều này cho phép việc chạy ứng dụng Silverlight
không phụ thuộc trình duyệt (Safari, FireFox, IE, ...) và hệ điều hành (Windows, Mac, và
Linux).
Các file HTML và ASP.NET để test cũng được thêm vào sẵn ngay khi tạo project, do vậy
chúng ta chỉ việc đơn giản là nhấn F5 để build, run và test.
SVTH: Thân Hoàng Lộc Trang 48
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
- Cách thêm vào các control và bắt các sự kiện
Hiện tại chương trình Digg của chúng ta vẫn chưa có gì, do vậy khi chạy nó các
bạn sẽ chỉ thấy một trang web trống. Chúng ta có thể thay đổi bằng cách mở file
Page.xaml và thêm vào một số nội dung:
Chúng ta sẽ bắt đầu bằng việc thay đổi màu nền của grid và khai báo một nút bấm
bên trong nó. Chúng ta cũng sẽ đặt vá trị cho thuộc tính "x:Name" của nút bấm thành
"MyButton" - điều này sẽ cho phép có thể tham chiếu đến nút bấm này khi lập trình,
chúng ta cũng sẽ đặt giá trị cho các thuộc tính Content, Width và Height:
SVTH: Thân Hoàng Lộc Trang 49
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
Khi chạy, chương trình của chúng ta sẽ hiển thị ở giữa trang với một nút bấm có
dòng chữ "Push Me" giống như sau:
SVTH: Thân Hoàng Lộc Trang 50
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
Để thêm một "hành vi" cho nút bấm, chúng ta có thể thêm một hàm xử lý sự kiện
"Click" cho nó, để thêm vào, chúng ta sẽ gõ vào tên sự kiện như sau:
Ngay khi đó, VS sẽ nhắc chúng ta thêm hàm xử lý sự kiện vào lớp code-behind:
Chúng ta có thể gõ vào tên của một phương thức mới mà chúng ta muốn tạo, hoặc
chỉ đơn giản nhấn Enter để dùng luôn tên mặc nhiên của nó:
SVTH: Thân Hoàng Lộc Trang 51
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
VS sẽ tự thêm vào một hàm xử lý sự kiện trong file code-behind. Chúng ta có thể
dùng hàm này để cập nhật nội dung của nút bấm mỗi khi nhấn chuột lên nó:
SVTH: Thân Hoàng Lộc Trang 52
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
Sau khi đã thay đổi giống như trên, chúng ta có thể chạy lại ứng dụng và nhấn lên
nút bấm lần nữa, bây giờ nội dung của nó sẽ được cập nhật lại thành "Pushed!":
SVTH: Thân Hoàng Lộc Trang 53
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 54
Nguyễn Anh Việt
Lưu Xuân Việt
Chương 2:
XAML - EXTENSIBLE APPLICATION MARKUP LANGUAGE
(Ngôn ngữ đánh dấu mở rộng)
I. KHÁI NIỆM XAML
1. XAML là gì?
XAML - Extensible Application Markup Language: là ngôn ngữ miêu tả. Bạn có
thể tạo và nhìn thấy các phần tử giao diện người dùng (UI) bên trong việc khai báo
XAML. Bạn cũng có thể sử dụng một file code-Behind tách biệt để đáp ứng những event
và vận dụng đối tượng bạn khai báo trong XAML. Một ngôn ngữ khai báo nền XML rất
trực quan cho việc tạo nên những giao diện từ những mẫu ban đầu tới sản xuất thực tế.
Nhất là những người không có nền thiết kế và kỹ thuật web.
File XAML được sinh ra từ file XML và có tên phần mở rộng là .xaml.
Ví dụ: Trình bày bên trong một file Silverlight cơ bản xaml:
<UserControl x:Class="MySilverlight.Page"
xmlns=""
xmlns:x="">
2. XAML phân biệt dạng chữ (XAML Is Case-Sensitive)
XAML là một ngôn ngữ phân biệt dạng chữ. Đây là điều khác biệt của XAML với
nền XML, sự phân biệt chữ này bởi sự định nghĩa ngôn ngữ XML. Tên của phần tử
XAML và thuộc tính phân biệt chữ. Giá trị của một thuộc tính là khả năng phân biệt chữ;
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 55
Nguyễn Anh Việt
Lưu Xuân Việt
Điều này sẽ phụ thuộc vào giá trị thuộc tính là như thế nào với handle thuộc tính chung.
Chẳng hạn như, Nếu giá trị thuộc tính khai báo một bảng liệt kê các tên thành viên. Việc
built-in các hành động mà biến đổi các kiểu một chuỗi tên thành viên rồi trả về giá trị của
thành viên trong bảng liệt kê là không có sự phân biệt dạng chữ. Ngược lại, giá trị của
thuộc tính Name tốt hơn những phương thức tiện ích trong sự làm việc với những đối
tượng cơ bản trên cái tên mà đã khai báo thuộc tính Name, có sự phân biệt chữ trong
chuỗi tên đó.
II. CÚ PHÁP KHAI BÁO
Trình bày đối tượng (Declaring Objects)
Có hai cách trình bày đối tượng trong Silverlight:
• Trực tiếp, khai báo cú pháp phần tử đối tượng: Sử dụng việc mở và đóng tag để
khai báo một đối tượng như là một phần tử XML. Bạn có thể sử dụng cú pháp khai
báo đối tượng root hoặc set các giá trị thuộc tính.
• Gián tiếp, khai báo cú pháp thuộc tính: Sử dụng một giá trị bên trong để khai báo
một đối tượng. Bạn có thể sử dụng cú pháp này để set giá trị của thuộc tính. Đây là
một thao tác gián tiếp trong xử lý của XAML, bởi vì chỉ có một vài chuỗi bên dưới
nhận biết làm thế nào để khởi tạo đối tượng mới trên cơ sở thuộc tính đang set và
chuỗi giá trị cung cấp là gì. Tiêu biểu, điều này nghĩa là kiểu và thuộc tính trong
vấn đề hỗ trợ việc chuyển đổi kiểu để có thể làm việc với những chuỗi nhập vào.
Điều này không có nghĩa là bạn luôn có sự lựa chọn trong khai báo cú pháp phần
tử đối tượng hoặc cú pháp thuộc tính nào. Tất nhiên những đối tượng chỉ có thể được khởi
tạo khi khai báo cú pháp phần tử đối tượng. Một số ít các đối tượng chỉ có thể được tạo
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 56
Nguyễn Anh Việt
Lưu Xuân Việt
khi đã set các giá trị thuộc tính ban đầu. Đối tượng mà có thể được tạo với những phần tử
đối tượng khác hoặc cú pháp thuộc tính là tương đối ít thấy trong Silverlight.
1. Khai báo một đối tượng bằng cách khai báo cú pháp phần tử đối tượng
(Declaring an Object by Using Object Element Syntax)
Để khai báo một đối tượng bằng cách khai báo cú pháp phần tử đối tượng, bạn viết
bằng hai phần tử tag sau đây:
objectName là tên của đối tượng bạn muốn thể hiện.
Ví dụ: Cú pháp khai báo một đối tượng Canvas:
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 57
Nguyễn Anh Việt
Lưu Xuân Việt
Một sự tiện lợi là: nếu đối tượng không chứa những đối tượng khác, bạn có thể
khai báo phần tử đối tượng bằng cách sử dụng một tag đóng thay vì một cặp tag mở/đóng,
ví dụ như tag trong ví dụ sau:
2. Khai báo một đối tượng sử dụng cú pháp thuộc tính (Declaring an Object by
Using Attribute Syntax)
Trong một vài trường hợp, nơi mà chứa giá trị thuộc tính không nguyên thủy là
một chuỗi, bạn có thể sử dụng cú pháp thuộc tính để khai báo kiểu đối tượng và set cả hai
đặc tính cho đối tượng đó. Trong đó, có một đặc tính chính để định nghĩa đối tượng mới.
Bởi vì những hành vi này thường trú trong thuộc tính của đối tượng.
III. SETTING PROPERTIES
Bạn có thể set các thuộc tính trên đối tượng mà bạn khai báo bằng cách sử dụng cú
pháp phần tử đối tượng. Có nhiều cách để set các thuộc tính trong XAML:
• Sử dụng cú pháp thuộc tính.
• Sử dụng cú pháp phần tử đặc tính.
• Sử dụng cú pháp phần tử nội dung.
• Sử dụng một cú pháp tập hợp.
Giống như việc khai báo một đối tượng, danh sách kỹ thuật này không đưa ra hay
dựa vào việc set thuộc tính với bất kỳ kỹ thuật nào. Một vài thuộc tính chỉ có thể áp dụng
duy nhất một kỹ thuật. Một vài thuộc tính lại có thể sử dụng kết hợp. Ví dụ như một thuộc
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 58
Nguyễn Anh Việt
Lưu Xuân Việt
tính mà những sự hỗ trợ cúp pháp phần tử nội dung cũng có thể được hỗ trợ cú pháp phần
tử đặc tính hoặc cú pháp thuộc tính. Điều này phụ thuộc vào thuộc tính sử dụng là trên
thuộc tính hay trên loại đối tượng. Cú pháp XAML được cung cấp bên trong phần
"XAML Usage" của những trang tham chiếu cho mỗi thuộc tính có thể set trong XAML.
Silverlight cũng có thuộc tính mà không thể set trong XAML nhưng có thể set khi khai
báo code.
Không có cánh nào để có thể set thuộc tính Read-only, kể cả trong XAML hoặc
trong code trừ khi có một kỹ thuật thêm vào trong lúc phát. Có thể gọi một hàm khởi tạo
bên ngoài và set nội dung thuộc tính muốn trình bày trong hàm đó. Một phương thức mà
không hoàn toàn truy xuất thuộc tính, hoặc một quan hệ thuộc tính như là thuộc tính tính
toán phải dựa vào giá trị thuộc tính trên bảng tính, có thể cộng thêm một dịch vụ hoặc một
hành vi tác động trên giá trị thuộc tính đó. Ngoài ra, những tập hợp đưa ra sự xuất hiện
mà bạn có thể set thuộc tính Read-only nhưng thực tế là không phải như vậy.
1. Khai báo cú pháp thuộc tính trong việc set một đặc tính (Setting a Property by
Using Attribute Syntax)
Sử dụng cú pháp sau:
Hoặc:
<!-- không đặt nội dung phần tử con ở đây nếu kiểu nội
dung của phần tử không cho phép -->
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 59
Nguyễn Anh Việt
Lưu Xuân Việt
objectName: Tên đối tượng muốn trình bày.
propertyName: Tên của thuộc tính muốn set cho đối tượng.
propertyValue: Giá trị thuộc tính muốn set.
Ví dụ: Khai báo một hình chữ nhật với chiều rộng 100pixel, chiều cao 100pixel, và màu
viền là blue.
2. Khai báo cú pháp thuộc tính phần tử việc set một đặc tính (Setting a Property by
Using Property Element Syntax)
Để sử dụng cú pháp này, cần tạo những phần tử XML cho thuộc tính muốn set.
Những phần tử này được đặt trong mẫu . Trong XML chuẩn, phần tử
này chỉ là một phần tử miêu tả chỉ xảy ra khi có một chấm trong tên của nó. Ngoài ra,
trong XAML dấu chấm trên tên của phần tử khai báo một thuộc tính của phần tử đó. Và
thuộc tính này cũng là thuộc tính của đối tượng.
Sử dụng cú pháp:
propertyValueAsObjectElement
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 60
Nguyễn Anh Việt
Lưu Xuân Việt
: property là tên thuộc tính muốn set cho đối tượng.
propertyValueAsObjectElement: khai báo một đối tượng mới với kiểu
giá trị tùy thích .
Ví dụ:
3. Khai báo cú pháp set đặc tính nội dung phần tử (Setting a Property by Using
Content Element Syntax)
Một vài đối tượng Silverlight xác định một thuộc tính mà cho phép một cú pháp
XAML, nhờ đó bạn có thể bỏ qua tên thuộc tính và set thuộc tính một cách dễ dàng bởi sự
cung cấp một giá trị bên trong những tab riêng chứa kiểu của phần tử đối tượng. Đây
nghĩa là cú pháp phần tử nội dung. Nếu cú pháp phần tử nội dung là sẵn có, cú pháp này
sẽ đưa ra bên trong phần sử dụng XAML cho thuộc tính bên trong Silverlight tham chiếu
tới.
Ví dụ:
Trang thuộc tính Text cho TextBlock luân phiên đưa ra cú pháp XAML mà sử
dụng cú pháp phần tử nội dung thay vì sử dụng cú pháp thuộc tính để set giá trị chuỗi
Text.
Set giá trị thuộc tính Text của TextBlock mà hoàn toàn không dùng thuộc tính
Text. Trong trường hợp này, thuộc tính set là khai báo những gì bên trong nội dung XML
hoặc “nội bộ text” hơn là khai báo những thuộc tính hoặc trình bày một phần tử đối
tượng.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 61
Nguyễn Anh Việt
Lưu Xuân Việt
Hello!
4. Khai báo cú pháp tập hợp (Setting a Property by Using a Collection Syntax)
Tập hợp là một trường hợp cần quan tâm trong XAML, bởi vì có vài biến đối trong
cú pháp tập hợp. Vì vậy, khả năng đầu tiên trong XAML là coi việc set này như Read-
only cho tập thuộc tính. Trong thực tế, XAML ở đây thêm những Item vào trong tập hợp.
Thuộc tính của kiểu tập hợp luôn được lấy là thuộc tính tập hợp các Item. Thỉnh
thoảng điều này luôn được bỏ qua từ cú pháp tập hợp XAML. Trong nhiều trường hợp,
thuộc tính này được khai báo như là một chỉ mục CLR. Đối với những tập hợp, thuộc tính
thực ra không phải là điều quan trọng để bất cứ cái gì là hữu ích với tập hợp từ XAML mà
là việc thêm một phương thức. Như vậy, khi bắt gặp xử lý XAML một hoặc nhiều phần tử
đối tượng bên trong một cú pháp tập hợp, mỗi đối tượng này như là được tạo ra đầu tiên,
và mỗi đối tượng mới là việc thêm vào trong tập hợp điều này được gọi là phương thức
thêm của tập hợp.
Ví dụ:
<!-- Here the GradientStopCollection tag is
specified. -->
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 62
Nguyễn Anh Việt
Lưu Xuân Việt
Bên cạnh đó, trong sự tổng quát của một thuộc tính Silverlight mà nắm bắt một tập hợp,
các phân tách XAML hoàn toàn biết kiểu nào là của tập hợp cơ bản trong thuộc tính tập
hợp chứa đựng nó. Vì vậy, bạn có thể bỏ qua thuộc tính của đối tượng đối với chính tập
hợp đó. Như ví dụ bên dưới:
<!-- no explicit new GradientStopCollection, parser
knows how to find or create -->
Hơn nữa, có một thuộc tính được gọi là thuộc tính tập hợp, nhưng nó cũng chỉ nhận dạng
như là một thuộc tính bên trong cho lớp đó. Trường hợp này với thuộc tính GradientStops
sử dụng trong ví dụ trên. Vì vậy, bạn cũng có thể bỏ quên thuộc tính của đối tượng, kết
quả tạo thành:
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 63
Nguyễn Anh Việt
Lưu Xuân Việt
Sự kết hợp này của tập hợp và cú pháp nội dung là sự phổ biến thường thấy trong
những lớp mà sử dụng một cách tổng quát cho những cotrol kết hợp, chẳng hạn như
những Panel.
Ví dụ:
Hello
World
Hello
World
5. Khi nào thì sử dụng thuộc tính hoặc cú pháp đặc tính phần tử để set thuộc tính?
(When to Use Attribute or Property Element Syntax to Set a Property )
Tất cả các đặc tính mà được hỗ trợ để Set trong XAML sẽ hỗ trợ các thuộc tính
hoặc cú pháp đặc tính phần tử trong việc set trực tiếp các giá trị,. Nhưng có khả năng sẽ
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 64
Nguyễn Anh Việt
Lưu Xuân Việt
không hỗ trợ cho những cú pháp thay thế tương tự. Một vài thuộc tính không hỗ trợ cú
pháp này, và một vài thuộc tính hỗ trợ thêm vào những cú pháp tùy chọn, chẳng hạn cú
pháp nội dung phần tử để đưa ra đoạn text như ở trên.
XAML hỗ trợ từng phần sẽ có những kiểu thuộc tính riêng trong cú pháp. Nếu kiểu
của thuộc tính là kiểu nguyên thủy, chẳng hạn như: double, integer, hoặc string thì những
cú pháp thuộc tính hỗ trợ cũng có kiểu như vậy.
Ví dụ sử dung cú pháp thuộc tính để set độ rộng của hình chữ nhật. Thuộc tính độ
rộng hỗ trợ cú pháp thuộc tính bởi vì giá trị thuộc tính này là double:
Bạn cũng có thể sử dụng cú pháp thuộc tính để set một thuộc tính nếu kiểu đối
tượng mà bạn sử dụng để set mà thuộc tính có thể được tạo ra bởi sự chuyển đổi thuộc
tính một chuỗi. Bên cạnh đó, chắc chắn những kiểu của đối tượng khác cũng có thể được
tạo bằng cách định nghĩa một chuỗi như là một giá trị thuộc tính (Thay vì phụ thuộc vào
cú pháp phần tử đối tượng). Kỹ thuật này dựa trên cơ sở chuyển đổi kiểu, hỗ trợ nhiều cho
những thuộc tính riêng hơn là thuộc tính chung trong những kiểu thuộc tính. Chuỗi giá trị
của thuộc tính là từng phần và chuỗi thông tin là sử dụng set thuộc tính chủ yếu cho
những đối tượng mới khởi tạo. Đôi khi, một kiểu chuyển đổi đặc biệt cũng có khả năng
tạo những phân lớp khác nhau của những kiểu thuộc tính phổ biến, phụ thuộc vào thông
tin xử lý duy nhất như thế nào trong chuỗi. Kiểu đối tượng mà hỗ trợ hành vi này sẽ có
một danh sách ngữ pháp đặc biệt trên từng phần tài liệu cú pháp.
Ví dụ sau sử dụng cú pháp thuộc tính set Fill của một hình chữ nhật. Thuộc tính
Fill hỗ trợ một cú pháp thuộc tính khi bạn sử dụng SolidColorBrush để set nó. Bởi vì kiểu
trừu tượng Brush đằng sau thuộc tính Fill hỗ trợ một kiểu chuyển đổi ngữ pháp mà có thể
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 65
Nguyễn Anh Việt
Lưu Xuân Việt
tạo ra một SolidColorBrush cùng lúc với thuộc tính. Trên lý thuyết chuỗi này là một
Color:
Bạn có thể sử dụng cú pháp phần tử thuộc tính để set một thuộc tính nếu đối tượng
bạn sử dụng để set thuộc tính hỗ trợ cú pháp phần tử thuộc tính. Nếu đối tượng hỗ trợ cú
pháp đối tượng thuộc tính đối tượng, thuộc tính cũng hỗ trợ cú pháp phần tử thuộc tính.
Ví dụ sử dụng cú pháp thuộc tính phần tử để set Fill một hình chữ nhật. Thuộc tính Fill hỗ
trợ cú pháp phần tử thuộc tính khi bạn sử dụng SolidColorBrush để set nó. Bởi vì
SolidColorBrush hỗ trợ cú pháp phần tử đối tượng và đáp ứng yêu cầu thuộc tính với giá
trị được set là một kiểu của Brush.
Bởi vì kiểu chuyển đổi của Brush, SolidColorBrush xảy ra chỉ với trường hợp
Brush nơi mà bạn có thể chọn cú pháp phần tử thuộc tính này hay cú pháp thuộc tính kia
cho một giá trị Fill mới. Với những kiểu Brush khác bạn có thể sử dụng việc set Fill sử
dụng một kiểu Brush như là ImageBrush . Bạn chỉ nên sử dụng cú pháp thuộc tính phần
tử cho Fill và khai báo một ImageBrush như là một phần tử đối tượng cung cấp giá trị
thuộc tính hoặc sử dụng tạo một phần mở rộng.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 66
Nguyễn Anh Việt
Lưu Xuân Việt
IV. THÀNH PHẦN MỞ RỘNG (Markup Extensions)
Thành phần mở rộng là một khái niệm của ngôn ngữ XAML, thường được sử dụng
trong sự thi hành của Silverlight XAML. Trong cú pháp thuộc tính của XAML, cặp dấu
ngoặc ({ và }) thường dùng để chỉ phần mở rộng do XAML qui định. Cách sử dụng này
giúp cho những xử lý của XAML tránh được những xử lý chung của giá trị thuộc tính
cũng như là những chuỗi khác hoặc những giá trị chuỗi thường thay đổi. Thay vào đó,
một kiểu phân tách gọi code diễn ra ngay sau phần mở rộng nhằm giúp cho việc khởi tạo
một cây đối tượng.
Silverlight hỗ trợ ba cách mở rộng đã được định nghĩa bên dưới Namespace XML
và được hiểu ngầm trong phân tích cú pháp XAML. Bao gồm: Binding, StaticResource,
và TemplateBinding. Binding hỗ trợ việc liên kết data. StaticResource hỗ trợ việc tham
chiếu tài nguyên đã được khai báo trong một ResourceDictionary. TemplateBinding hỗ
trợ những control Template trong XAML mà có thể tương tác với thuộc tính code của đối
tượng Template. Silverlight cũng thi hành một sự mở rộng mà được khai báo bên trong
Namespace XAML x:Null.
Ví dụ:
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 67
Nguyễn Anh Việt
Lưu Xuân Việt
...
...
V. EVENTS
XAML là một ngôn ngữ khai báo cho đối tượng và những thuộc tính của đối
tượng, nhưng nó cũng bao gồm một cú pháp cho việc kèm theo những event handler tới
đối tượng trong phần khởi tạo. Bạn có thể chỉ rõ tên event như là một tên thuộc tính trên
đối tượng mà có event xảy ra. Với những giá trị thuộc tính, bạn có thể chỉ định rõ tên của
những hàm event-handler mà bạn khai báo trong code. Xử lý XAML sử dụng tên này tạo
một mô tả đại diện trong cây đối tượng tải lên và thêm những handler tới danh sách
handler bên trong.
Trong XAML, API thường sử dụng (managed hoặc JavaScript) ảnh hưởng tới kỹ
thuật của chỉ định những event handler. API loại trừ lẫn nhau trên từng vi trí của trang
XAML. Dấu hiệu cho mỗi API hiện hành là sự có mặt hay vắng mặt của x:lớp thuộc tính
trên phần tử root của trang. Nếu x: lớp đã tồn tại, thì trang sử dụng managed API. Nếu x:
lớp không tồn tại, trang sẽ sử dụng JavaScript API.
Trong managed API, event handler chỉ tồn tại trong file code-behind mà kết hợp
với trang XAML hiện tại. Bởi vì những lớp riêng này từ XAML và code thỉ tham gia vào
trong việc thêm vào một handler.
Ví dụ: event Loaded cho một Canvas:
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 68
Nguyễn Anh Việt
Lưu Xuân Việt
<Canvas xmlns=
Loaded="onLoaded" />
Tên hàm onLoaded được khai báo bên trong file JavaScript. File JavaScript này kết hợp
với HTML của trang chính thông qua tham số src của tag trong HTML.
<!-- Reference the JavaScript file where the event
functions are defined
from the plug-in host HTML page. -->
...
VI. XAML, EVENTS, và CODE-BEHIND
Hầu hết ứng dụng nền Silverlight đều được sinh ra từ markup và code-behind.
Trong một project, XAML dùng để viết như là một file .xaml và một ngôn ngữ CLR như
là Visual Basic hoặc C# viết file code-behind . Khi một file XAML biên dịch, vị trí của
file code-behind cho mỗi trang XAML được nhận ra bởi một Namespace và một lớp
x:class thuộc tính của phần tử root của trang XAML.
Ứng dụng chính – mức kỹ thuật cho việc thêm vào một hành vi cho phần tử đối
tượng là sử dụng một event đã tồn tại của lớp, và viết một handle riêng triệu gọi event này
khi xuất hiện trong thời gian thực thi. Tên event và tên của handler được sử dung theo
kiểu đã được dựng trước, trong khi code thi hành những handler này đã được khai báo
trong code-behind.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 69
Nguyễn Anh Việt
Lưu Xuân Việt
VII. NHỮNG PHẦN TỬ ROOT XAML VÀ xmlns (XAML Root Elements
and xmlns)
Một file XAML chỉ chứa một phần tử root.
Ví dụ: trình bày một phần tử root của XAML đặc trưng cho trang Silverlight với phần tử
root UserControl:
<UserControl x:Class="MySilverlight.Page"
xmlns=""
xmlns:x="">
Phần tử root cũng chứa đựng thuộc tính xmlns và xmlns:x. Hai thuộc tính này cho
biết bộ xử lý XAML mà Namespace XML nào chứa phần tử định nghĩa cho các phần tử
mà nó tham chiếu tới.
Thuộc tính xmlns trong ví dụ trên cho biết rõ Namespace XML mặc định. Trong
Namespace XML mặc định, những phần tử đối tượng trong markup có thể đưa ra mà
không được dự báo trước. Trong Silverlight, Namespace XML mặc định luôn luôn là
Silverlight client namespace
.lns:x thuộc tính trong ví dụ trên cho biết Namespace XML đã thêm vào. Bản đồ
Namespace trong ngôn ngữ XAML
. Thành phần ngôn
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 70
Nguyễn Anh Việt
Lưu Xuân Việt
ngữ khai báo bởi Namespace XAML bắt đầu bằng: x: khi tham chiếu trong markup của
một file với bản đồ này. Cách sử dụng này của xmlns định nghĩa một phạm vi cho cách sử
dụng và bản đồ thích hợp, được nêu rõ trong XML 1.0. Chú ý thuộc tính xmlns là duy
nhất cần thiết trên phần tử root cho mỗi trang và xác định cho mỗi ứng dụng nếu nó được
cung cấp trong markup. Định nghĩa xmlns áp dụng cho tất cả các phần tử con của root, và
cũng áp dụng cho bất kỳ phần tử con trong những phần tử đã khai báo. Tuy nhiên, cách sử
dụng này không phải là điểm mạnh trong Silverlight, bởi vì sự định nghĩa thường xuyên
hoặc định nghĩa lại Namespace XML có thể đưa ra những kết quả đọc được khác nhau
trong kiểu XAML markup.
Để tùy chỉnh những assemblies riêng hoặc những assemblies bên ngoài Silverlight
bạn có thể chỉ định rõ assembly như trong phần bản đồ Namespace XML. Tuy nhiên, bạn
chọn một tiền tố khác và không phải giá trị mặc định như Namespace, nhưng nó cũng có
một sự lựa chọn khác Namespace XML như là giá trị mặc định và khi đó nó vạch ra cho
Silverlight một tiếp đầu ngữ.
Tiếp đầu ngữ x: (The x: Prefix)
Trong ví dụ phần tử root ở trên, tiếp đầu ngữ x: đã được sử dụng tới bản đồ
Namespace XAML
Tiếp đầu ngữ x: này sử dụng bản đồ Namespace XAML trong những Template cho
project nền Silverlight, trong ví dụ và xuyên suốt tài liệu này. Tiếp đầu ngữ x:/ XAML
Namespace chứa đựng vài cấu trúc lập trình mà bạn sẽ sử dụng khá thường xuyên trong
XAML. Sau đây là x: prefix/XAML namespace trong khởi tạo lập trình phổ biến mà bạn
sẽ sử dụng:
• x:Key: set một khóa duy nhất cho mỗi tài nguyên trong ResourceDictionary.
• x:Class: chỉ định rõ Namespace DLR và class name mà được tạo ra trong khi biên
dịch backup. Bạn chỉ có một lớp hỗ trợ code-behind, hoặc hỗ trợ khởi tạo như là
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 71
Nguyễn Anh Việt
Lưu Xuân Việt
RootVisual, và nó đưa ra những lý do để bạn luôn thấy x:mapped ngang cấp nếu
không có tài nguyên.
• x:Name: Định rõ tên một đối tượng thực thi cho trường hợp tồn tại code thực thi
sau khi một phần tử đối tượng khai báo trong XAML được xử lý. Bạn sử dung
x:Name cho tên kịch bản thường xuyên gặp trong nhiều nơi thuận tiện thuộc tính
FrameworkElement.Name không hỗ trợ như là trong storyboards
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 72
Nguyễn Anh Việt
Lưu Xuân Việt
Chương 3:
CHI TIẾT MỘT SỐ THÀNH PHẦN NGÔN NGỮ TRONG
THIẾT KẾ TRỰC QUAN
I. SILVERLIGHT LAYOUT SYSTEM
Layout System là gì?
Thuật ngữ “Layout” mô tả kích thước và vị trí của những phần tử thành phần tập
hợp con (Children) trong một Panel và vẽ chúng lên trên màn ảnh. Ở đây tập trung
những tiến trình, những tập hợp con (Children) rộng lớn và mức độ xử lý quy mô. Sự
phức tạp cũng dựa trên cơ sở những khai báo thể hiện ra bên ngoài bởi những tập hợp
riêng và những phần tử Panel. Một liên tưởng đơn giản như Canvas có thể đưa ra
những thực thi chính xác trong một Panel phức tạp nhưng Grid thì lại không đáp ứng
được.
Mỗi một thời điểm. các con (Children) trong UIElement thay đổi vị trí, nó có khả
năng sinh ra thành công một tiến trình mới bởi hệ thống thể hiện. Đó là điều quan
trọng để hiểu được các sự kiện có thể gọi hệ thống thể hiện, bởi vì những lệnh gọi
không cần thiết có thể làm cho sự thực thi một trình ứng dụng trở nên nghèo nàn.
Điều đơn giản, Layout là một hệ thống đệ quy mà các bước của nó là sự điều chỉnh
vị trí, kích thước và cách thể hiện ra màn hình. Để xây dựng thành công một hệ thống
Layout cần chú ý 2 điểm đối với mỗi thành phần tập hợp con (Children), thứ nhất là
xác định phạm vi và thứ 2 là xác định cách bố trí. Phạm vi là vị trí đã được xác định rõ
kích thước cho mỗi phần tử con. Cách bố trí phụ thuộc vào vị trí và kích thước của các
phần tử con sau khi đã cân chỉnh.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 73
Nguyễn Anh Việt
Lưu Xuân Việt
1. Cách thể hiện SilverLight trong hệ thống.
- Vị trí và kích thước của trình nhúng (plug-in) Silverlight.
Trình nhúng Silverlight xác định rõ khu vực mà trình ứng dụng Silverlight cơ bản
thể hiện trên đó. Chúng ta có thể gắn kết trình nhúng này vào trang chủ HTML.
Chúng ta cũng có thể chỉ định rõ một nơi nào đó trong trang HTML đang thể hiện
hoặc chúng ta cũng có thể đưa toàn bộ trình nhúng này lên trên một trang HTML.
Bởi vì chúng có hai cấu trúc tham chiếu tới vị trí đối tượng SilverLight.
- Phạm vi trình nhúng: Vị trí thể hiện đối tượng của SilverLight chỉ trong phạm vi
giới hạn của hộp thoại trình nhúng.
- Phạm vi HTML: Toàn bộ trình nhúng và tất cả vị trí của các đối tượng trong trình
nhúng phụ thuộc vào nơi mà chúng ta đặt trình nhúng trong HTML.
- Việc thêm một trình nhúng SilverLight vào một trang web có hai cách:
o Sử dụng HTML: Tất cả những phần tử đối tượng chúng ta cho phép nhúng
và định hình rõ trình nhúng SilverLight ( SilverLight plug-in) trong trang
HTML, vạch ra hướng mà có sự tương thích với tất cả sự hỗ trợ của người
dùng. Chủ đề này mô tả làm thế nào chúng ta hoàn tất, phổ biến những yêu
cầu tiếp theo sử dụng những phần tử đối tượng:
Nhúng một SilverLight và chỉ định rõ ứng dụng trên trang chủ.
Định rõ việc luân phiên việc trình bày bằng HTML khi SilverLight
không cài đặt được.
Trong trang HTML các thao tác này hoàn toàn khác, cái khác biệt rõ ràng nhất là
cách cấu hình tham số truyền của các phần tử đối tượng. Theo những procedure
mô tả trong một trình độc lập nhưng chỉ xây dựng hoàn tất một trình duyệt đa
nhiệm HTML ví dụ ở cuối chương này.
Chúng ta nên sử dụng kết quả của những ví dụ này như là một mẫu
(Template) cho project thay vì sử dụng những phần con trong mỗi procedure. Kết
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 74
Nguyễn Anh Việt
Lưu Xuân Việt
quả của những ví dụ này cũng đảm bảo sự tương thích giữa các trình duyệt với
nhau và cũng là cơ sở trong các mẫu (Template) mà Visual Studio và Expression
Blend sử dụng để kiểm tra những trang đã sinh ra.
2. Đối tượng tham chiếu trong trình nhúng (plug-in) Silverlight.
Trình nhúng Silverlight là một đối tượng mà có thể sử dụng những kiểu lập trình
và truy xuất dữ liệu khác nhau. Những thành phần của lớp Plug-in có thể được truy xuất
thông qua phương thức HTML DOM và thông qua những phần tử đối tượng đã được định
nghĩa trên nền Silverlight plug-in trong một trang HTML. Tương tự những hàm cũng
được truy xuất thông qua APIs mà đưa ra trang HTML dạng xuất ra như đối tượng những
thẻ. Cũng giống như trong ASP.NET, Silverlight và những trình nhúng Silverlight được
điều khiển trên trang Web máy chủ và những hàm trong thư viện Silverlight.js. Một vài
hàm trong trình nhúng Silverlight có thể được truy xuất trong quá trình chạy (Run-time)
bởi chúng được sử dụng trong những mô hình lập trình Silverlight (the JavaScript API or
managed code).
- Sử dụng JavaScrip: Cách khác, chúng ta cũng có thể khai báo những đối tượng sử
dụng thông qua những hàm mà JavaScrip cung cấp trong file Silverlight.js. Những
hàm này tạo ra đối tượng cơ bản và cung cấp như là những tiện nghi trong sự trình bày
của JavaScrip.
o Silverlight.js là một file hướng dẫn được cung cấp trong Silverlight SDK. Ta có
thể gọi các hàm createObject và createObjectEx khai báo file này khi nhúng
Silverlight Plug-in vào trang web. Gọi chung những hàm này là hàm nhúng.
o Những hàm nhúng này cho phép cấu hình chi tiết những tham số vào và sinh ra
những đối tượng HTML. Kỹ thuật nhúng này tương thích với tất cả sự hỗ trợ
các trình duyệt.
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 75
Nguyễn Anh Việt
Lưu Xuân Việt
- Các hàm nhúng này cung cấp thêm các lợi ích sử dụng các đối tượng ngay khi:
o Chúng cho phép ta cấu hình một trương trình Silverlight plug-in khi ta
nhúng vào, hoặc trừu tượng hóa chi tiết một cấu hình độc lập, một hàm
dùng chung.
o Chúng vẫn tương thích ngược lại với các hàm createObject và
createObjectEx trong Silverlight 1.0.
o Mỗi Plug-in nhúng vào có một nét riêng cho phép ta nhận dạng chúng. Điều
này rất hữu ích khi nhúng nhiều Plug-in vào một trang web đơn.
3. The Layout Containers
Một cửa sổ Silverlight chỉ có thể chứa duy nhất một phần tử đơn lẻ. Để chứa nhiều
hơn một phần tử và tạo ra nhiều giao diện người dùng thực tế. Bạn cần phải có một chỗ
chứa trên một trang và sau đó thêm những phần tử ấy vào chỗ chứa này. Giao diện này đã
được định rõ bởi khuôn chứa bạn đã sử dụng.
Tất cả những Layout Container là những bảng có nguồn gốc từ lớp trừu tượng
System.Windows.Controls.Panel
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
Hình 1: Bảng phân cấp lớp Panel
Lớp Panel thêm vào 2 thuộc tính chung là: Background và Children. Background là
bộ bút vẽ sử dụng để sơn màu nền của Panel. Children là tập hợp những mục mà lưu trữ
trên Panel. Đây là mức thứ nhất của các phần tử - Trong một phát biểu khác, bản thân
những phần tử này cũng có thể chứa đựng nhiều phần tử khác.
Nói riêng, lớp Panel không chỉ là một lớp cơ bản mà còn là một điểm bắt đầu cho
nhiều lớp chuyên dụng khác. Để thuận tiện trong việc sắp đặt layout, Silverlight cung cấp
3 loại Panel như hinh 2. Cũng giống như hầu hết các trình điều khiển trong Silverlight và
nhất là những phần tử trực quan. Những lớp này cũng được xây dựng trên
System.Windows.Controls namespace.
Tên Mô tả
StackPanel Nơi những phần tử được xếp thành
hàng ngang hay hàng dọc. Bao chứa
SVTH: Thân Hoàng Lộc Trang 76
Nguyễn Anh Việt
Lưu Xuân Việt
Báo cáo đồ án tốt nghiệp GVHD: TS. NGUYỄN CHÁNH THÀNH
SVTH: Thân Hoàng Lộc Trang 77
Nguyễn Anh Việt
Lưu Xuân Việt
Layout này chia những thành phần lớn,
những trang phức tạp thành những phần
nhỏ tiêu biểu thưởng sử dụng.
Grid Sắp xếp các phần tử trong hàng và cột
tùy theo sự ẩn hiện của bảng. Đây là
một tính mềm dẻo nhất và thường sử
dụng với những bao chứa Layout.
Canvas Cho phép những phần tử có một vị trí
tuyệt đối sử dụng hệ tọa độ cố định.
Bao chứa Layout này là một bao chứa
đơn nhưng nó có tính mềm dẻo.
Những bao chứa Layout có thể xếp chồng nhau. Một giao diện người dùng điển hình bắt
đầu với Grid, Silverlight hoàn toàn có khả năng sinh ra bao chứa, và chứa đựng những
bao chứa Layout khác mà đã nhóm nhỏ và sắp xếp những phần tử lại. Chẳng hạn như:
một TextBoxes tiêu đề, những Item trong List, những Icon trên ToolBar và v…v…
a. StackPanel:
Sắp xếp các phần tử con theo một đường thẳng đơn theo hướng ngang hoặc dọc.
Mặc định của giá trị HorizontalAlignment và VerticalAlignment là trạng thái
Stretch.
Giá trị mặc định của thuộc tính Orientation là dọc (Vertical).
Các sự kiện của StackPanel: Ngoài các sự kiện
Các file đính kèm theo tài liệu này:
- NGHIEN CUU SILVERLIGHT VA XAY DUNG UNG DUNG WEB HO TRO PHAT TRIEN BAI GIANG DANG MULTIMEDIA.pdf