Silverlight - CSS
Karena konten Silverlight selalu berjalan di dalam halaman web, tag objek tunduk pada aturan tata letak CSS normal. Tidak ada cara bagi pengaya untuk mendorong ukuran yang diinginkan kembali ke peramban, jadi berapa pun ukuran konten Silverlight yang diinginkan, ukuran dan posisinya akan sepenuhnya ditentukan oleh laman web yang memuatnya.
Template proyek Silverlight default menempatkan CSS di halaman web yang memberikan tag objek ke seluruh jendela browser.
XAML default tampaknya memiliki ukuran tetap, tetapi jika Anda melihat lebih dekat, Anda akan melihat bahwa template menyetel lebar desain, dan properti tinggi desain.
Ini memberi tahu Visual Studio, atau Blend, seberapa besar tampilan antarmuka pengguna di desainer, tetapi memungkinkan untuk mengubah ukuran saat runtime.
Di Solution Explorer kamu akan lihat {project name}TestPage.html file, yang merupakan HTML default yang Anda dapatkan saat membuat proyek Silverlight baru di Visual Studio seperti yang ditunjukkan di bawah ini.
CSS di bagian atas, menyetel HTML dan gaya tubuh menjadi 100%, yang mungkin tampak agak aneh.
Berikut adalah file html lengkap, yang berisi pengaturan berbeda.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns = "http://www.w3.org/1999/xhtml" >
<head>
<title>FirstExample</title>
<style type = "text/css">
html, body {
height: 100%;
overflow: auto;
}
body {
padding: 0;
margin: 0;
}
#silverlightControlHost {
height: 100%;
text-align:center;
}
</style>
<script type = "text/javascript" src = "Silverlight.js"></script>
<script type = "text/javascript">
function onSilverlightError(sender, args) {
var appSource = "";
if (sender != null && sender != 0) {
appSource = sender.getHost().Source;
}
var errorType = args.ErrorType;
var iErrorCode = args.ErrorCode;
if (errorType == "ImageError" || errorType == "MediaError") {
return;
}
var errMsg = "Unhandled Error in Silverlight Application " + appSource + "\n" ;
errMsg += "Code: "+ iErrorCode + " \n";
errMsg += "Category: " + errorType + " \n";
errMsg += "Message: " + args.ErrorMessage + " \n";
if (errorType == "ParserError") {
errMsg += "File: " + args.xamlFile + " \n";
errMsg += "Line: " + args.lineNumber + " \n";
errMsg += "Position: " + args.charPosition + " \n";
} else if (errorType == "RuntimeError") {
if (args.lineNumber != 0) {
errMsg += "Line: " + args.lineNumber + " \n";
errMsg += "Position: " + args.charPosition + " \n";
}
errMsg += "MethodName: " + args.methodName + " \n";
}
throw new Error(errMsg);
}
</script>
</head>
<body>
<form id = "form1" runat = "server" style = "height:100%">
<div id = "silverlightControlHost">
<object data = "data:application/x-silverlight-2,"
type = "application/xsilverlight-2" width = "100%" height = "100%">
<param name = "source" value = "ClientBin/FirstExample.xap"/>
<param name = "onError" value = "onSilverlightError" />
<param name = "background" value = "white" />
<param name = "minRuntimeVersion" value = "5.0.61118.0" />
<param name = "autoUpgrade" value = "true" />
<a href = "http://go.microsoft.com/fwlink/?LinkID=149156&v=5.0.61118.0"
style = "textdecoration:none">
<img src = "http://go.microsoft.com/fwlink/?LinkId=161376"
alt = "Get Microsoft Silverlight" style = "border-style:none"/>
</a>
</object>
<iframe id = "_sl_historyFrame" style = "visibility:hidden;height:0px;
width:0px;border:0px"></iframe>
</div>
</form>
</body>
</html>
Melihat ke silverlightControlHost, kita perlu memastikannya bintang dengan tinggi tetap, katakanlah 300 piksel, dan lebar 400 piksel, yang cocok dengan lebar dan tinggi desain default di XAML. Anda juga dapat mengubah pengaturan ini sesuai dengan kebutuhan aplikasi Anda.
Konten yang Tumpang Tindih
Secara default, konten Silverlight dan HTML tidak dapat berbagi ruang yang sama di layar. Jika Anda membuat konten dari keduanya, sehingga menempati ruang yang sama maka hanya konten Silverlight yang akan terlihat.
Ini karena, secara default, Silverlight akan meminta browser untuk jendela privatnya sendiri, merender semua konten ke dalamnya. Ini adalah jendela anak di dalam browser, sehingga terlihat seperti bagian dari halaman web, tetapi mencegah konten tumpang tindih.
Alasan utamanya adalah kinerja. Dengan menampilkan area privatnya sendiri di layar, Silverlight tidak harus mengoordinasikan renderingnya dengan browser web.
Namun, terkadang ada gunanya memiliki konten yang tumpang tindih. Ada harga kinerja yang harus dibayar. Anda mungkin menemukan bahwa animasi tidak berjalan semulus saat Silverlight dan HTML berbagi ruang di layar, tetapi fleksibilitas tata letak ekstra mungkin sepadan dengan harganya. Untuk menggunakan konten yang tumpang tindih, Anda perlu mengaktifkan mode Tanpa Jendela.
Dalam mode Tanpa Jendela, plugin Silverlight merender ke penangan jendela target yang sama dengan browser yang memungkinkan konten untuk berbaur.
Indeks Zed, atau indeks Z signifikan ketika isinya tumpang tindih. Sejauh menyangkut HTML, konten Silverlight adalah elemen HTML tunggal, sehingga muncul tepat di satu tempat dalam urutan HTML Z.
Ini berdampak pada penanganan mouse. Jika plugin Silverlight ada di bagian atas pesanan HMTL Z, aktivitas mouse apa pun di dalam kotak pembatasnya, akan dikirim ke plugin.
Meskipun beberapa area plugin transparan, dan Anda dapat melihat HTML di belakangnya, Anda tidak akan dapat mengkliknya.
Namun, jika Anda mengatur indeks Z dengan beberapa konten HTML di atasnya, itu akan terus menjadi interaktif meskipun tumpang tindih dengan konten Silverlight.
Contoh
Lihatlah contoh sederhana yang diberikan di bawah ini di mana kita memiliki layout dengan sebuah wadah, di mana tiga div semuanya telah diatur untuk tumpang tindih di dalam div yang berisi ini.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns = "http://www.w3.org/1999/xhtml" >
<head>
<title>HtmlOverlap</title>
<style type = "text/css">
#container {
position: relative;
height: 300px;
font-size: small;
text-align:justify;
}
#silverlightControlHost {
position: absolute;
width: 400px;
height: 300px;
}
#underSilverlight {
position: absolute;
left: 4px;
width: 196px;
}
#overSilverlight {
position: relative;
left: 204px;
width: 196px;
}
</style>
<script type = "text/javascript" src = "Silverlight.js"></script>
<script type = "text/javascript">
function onSilverlightError(sender, args) {
var appSource = "";
if (sender != null && sender != 0) {
appSource = sender.getHost().Source;
}
var errorType = args.ErrorType;
var iErrorCode = args.ErrorCode;
if (errorType == "ImageError" || errorType == "MediaError") {
return;
}
var errMsg = "Unhandled Error in Silverlight Application " +
appSource + "\n" ;
errMsg += "Code: "+ iErrorCode + " \n";
errMsg += "Category: " + errorType + " \n";
errMsg += "Message: " + args.ErrorMessage + " \n";
if (errorType == "ParserError") {
errMsg += "File: " + args.xamlFile + " \n";
errMsg += "Line: " + args.lineNumber + " \n";
errMsg += "Position: " + args.charPosition + " \n";
} else if (errorType == "RuntimeError") {
if (args.lineNumber != 0) {
errMsg += "Line: " + args.lineNumber + " \n";
errMsg += "Position: " + args.charPosition + " \n";
}
errMsg += "MethodName: " + args.methodName + " \n";
}
throw new Error(errMsg);
}
</script>
</head>
<body>
<form id = "form1" runat = "server" style = "height:100%">
<div id = 'container'>
<div id = 'underSilverlight'>
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
</div>
<div id = "silverlightControlHost">
<object data = "data:application/x-silverlight-2,"
type = "application/xsilverlight-2" width = "100%" height = "100%">
<param name = "source" value = "ClientBin/HtmlOverlap.xap"/>
<param name = "onError" value = "onSilverlightError" />
<param name = "background" value = "transparent" />
<param name = "windowless" value = "true" />
<param name = "minRuntimeVersion" value = "4.0.50401.0" />
<param name = "autoUpgrade" value = "true" />
<a href = "http://go.microsoft.com/fwlink/?LinkID=149156&v=4.0.50401.0"
style = "text-decoration:none">
<img src = "http://go.microsoft.com/fwlink/?LinkId=161376"
alt = "Get Microsoft Silverlight" style = "border-style:none"/> </a>
</object>
<iframe id = "_sl_historyFrame" style = "visibility:hidden; height:0px;
width:0px; border:0px"> </iframe>
</div>
<div id = 'overSilverlight'>
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
</div>
</div>
</form>
</body>
</html>
Div ini bergerak ke kiri, dan akan berada di belakang urutan Z, karena urutannya lebih dulu.
Kemudian di tengah, kami memiliki konten Silverlight yang akan mengisi seluruh lebar.
Kemudian di atas ini, ada div di sebelah kanan yang berisi teks- This is on top.
Diberikan di bawah ini adalah file XAML di mana satu persegi panjang ditambahkan dengan beberapa properti.
<UserControl x:Class = "HtmlOverlap.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d"
d:DesignHeight = "300" d:DesignWidth = "400">
<Grid x:Name = "LayoutRoot">
<Rectangle Margin = "0,120" Fill = "Aquamarine" />
</Grid>
</UserControl>
Saat Anda menjalankan aplikasi ini, Anda akan melihat dua kolom, satu bertuliskan di bawah di kiri, dan di atas di kanan. Plug-in Silverlight berada di area yang sama dengan keduanya, dan dalam urutan Z konten Silverlight berada di tengah keduanya.
Anda dapat melihat bahwa isian hijau semi-transparan di sini telah sedikit mewarnai teks di sebelah kiri karena berada di atasnya, tetapi tidak mewarnai teks di sebelah kanan, karena berada di belakang teks itu.
Anda dapat memilih teks di sebelah kanan. Jika Anda mencobanya dengan teks di sebelah kiri ini, tidak ada yang terjadi, dan itu karena, sejauh menyangkut browser, seluruh ruang di sini ditempati oleh kontrol Silverlight. Karena berada di atas teks dalam urutan Z, kontrol Silverlight yang menangani input.