Silverlight - Teks
Dalam bab ini, kita akan melihat apa yang Silverlight tawarkan untuk menampilkan teks. Blok teks digunakan untuk semua rendering teks dan Silverlight. Fitur penting lainnya adalah -
- Ini dapat digunakan untuk teks biasa sederhana atau Anda dapat menerapkan campuran gaya pemformatan.
- Silverlight mendukung satu set standar font bawaan.
- Anda juga dapat mengunduh font khusus ketika gaya visual aplikasi Anda membutuhkan sesuatu yang tidak biasa.
TextBlock
Untuk menampilkan teks kami menggunakan elemen buku teks Silverlight, yang merupakan kontrol ringan untuk menampilkan sejumlah kecil teks hanya-baca. Sebenarnya, kita sudah sering melihat ini karena penggunaan dasarnya tidak terlalu membutuhkan banyak penjelasan. Anda baru saja mengatur properti teks dan ini akan menampilkan teks itu untuk Anda.
<TextBlock Text = "Print Testing" HorizontalAlignment Center" FontFamily = "Georgia"/>
Warisan hierarki dari kelas TextBlock adalah sebagai berikut,
Diberikan di bawah ini adalah yang biasa digunakan properties dari TextBlock kelas.
No Sr | Deskripsi properti |
---|---|
1 | ContentEnd Mendapat objek TextPointer untuk akhir konten teks di TextBlock. |
2 | ContentStart Mendapat objek TextPointer untuk memulai konten teks di TextBlock. |
3 | IsTextSelectionEnabled Mendapat atau menyetel nilai yang menunjukkan apakah pemilihan teks diaktifkan di TextBlock, baik melalui tindakan pengguna atau memanggil API terkait pemilihan. |
4 | IsTextSelectionEnabledProperty Mengidentifikasi properti ketergantungan IsTextSelectionEnabled. |
5 | LineHeight Mendapat atau menyetel tinggi setiap baris konten. |
6 | MaxLines Mendapat atau menyetel baris teks maksimum yang ditampilkan di TextBlock. |
7 | SelectedText Mendapat rentang teks dari teks yang dipilih. |
8 | SelectionEnd Mendapat posisi akhir teks yang dipilih di TextBlock. |
9 | SelectionHighlightColor Mendapat atau menyetel kuas yang digunakan untuk menyorot teks yang dipilih. |
10 | SelectionStart Mendapat posisi awal dari teks yang dipilih di TextBlock. |
11 | Text Mendapat atau menyetel konten teks dari TextBlock. |
12 | TextAlignment Mendapat atau menetapkan nilai yang menunjukkan perataan horizontal konten teks. |
13 | TextTrimming Mendapat atau menyetel perilaku pemangkasan teks untuk diterapkan saat konten memenuhi area konten. |
14 | TextWrapping Mendapat atau menyetel bagaimana TextBlock membungkus teks. |
Diberikan di bawah ini biasanya digunakan events dari TextBlock kelas.
No Sr | Deskripsi acara |
---|---|
1 | ContextMenuOpening Terjadi ketika sistem memproses interaksi yang menampilkan menu konteks. |
2 | SelectionChanged Terjadi saat pemilihan teks telah berubah. |
Diberikan di bawah ini adalah yang biasa digunakan methods di TextBlock kelas.
No Sr | Metode & Deskripsi |
---|---|
1 | Focus Memfokuskan TextBlock, seolah-olah itu adalah kontrol yang dapat difokuskan secara konvensional. |
2 | Select Memilih rentang teks di TextBlock. |
3 | SelectAll Memilih seluruh konten di TextBlock. |
Lari
Terkadang Anda menginginkan kontrol yang sangat baik atas pemformatan dan pengaturan satu gaya untuk seluruh blok teks. Terkadang berguna untuk memformat kata satu per satu atau bahkan huruf, dan jika Anda menginginkannya, alih-alih menggunakanText properti, Anda meletakkan teks di dalam TextBlocksebagai konten. Jika Anda menggunakan kode, ini terkait dengan menambahkan item keTextBlock properti inline.
Dengan menggunakan pendekatan ini, Anda dapat menambahkan serangkaian elemen run. Setiap Proses mendukung keluarga font yang sama, bobot depan, latar depan, dan seterusnya untuk mengontrol gaya teks. Meskipun Run adalah elemen terpisah, ini tidak mengganggu aliran.
Mari kita lihat contoh sederhana, yang berisi banyak file Run elemen di dalamnya TextBlock. Diberikan di bawah ini adalah kode XAML.
<UserControl x:Class = "SilverlightRunDemo.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" Background = "White">
<TextBlock Width = "192" TextWrapping = "Wrap" FontFamily = "Verdana">
<Run Text = "Hello, " />
<Run FontWeight = "Bold" Text = "world!" />
<Run Text = "You" />
<Run FontStyle = "Italic" Text = " are " />
<Run Text = "learning" FontSize = "40" FontFamily = "01d English Text MT" />
<Run Text = " the " />
<Run Text = "basics of " Foreground = "Blue" />
<Run Text = " Silverlight." FontSize = "30" />
</TextBlock>
</Grid>
</UserControl>
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat output berikut.
Seperti yang Anda lihat, blok teks ini disusun dengan gaya pemformatan yang berbeda dengan menggunakan Run elemen.
Omong-omong, Anda tidak perlu membungkus setiap teks dalam satu proses. Anda dapat membiarkan sebagian besar konten blok teks sebagai teks biasa dan hanya menerapkanrun ke bagian-bagian yang membutuhkan format berbeda seperti yang ditunjukkan di bawah ini.
<TextBlock> Hello,
<Run FontWeight = "Bold" Text =" world!"/>
</TextBlock>
LineBreak
Silverlight biasanya mengabaikan jeda baris di XAML. Ini mengasumsikan bahwa sebagian besar ruang putih ada untuk membuatnya lebih mudah dibaca karena Anda sebenarnya ingin ruang itu muncul.
Mari kita lihat kode XAML ini, yang memiliki tiga baris teks terpisah di dalamnya.
<TextBlock>
This is not the end.
It is not even the beginning of the end.
But it is, perhaps, the end of the beginning
</TextBlock>
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat output berikut.
Seperti yang Anda lihat bahwa itu telah mengabaikan jeda baris dan mengeksekusi semua teks secara bersamaan.
Jika Anda mengaktifkan text wrapping, ini akan menempatkan jeda baris di tempat yang diperlukan untuk membuat teks pas tetapi akan mengabaikan jeda baris dalam contoh Anda.
Jika Anda hanya ingin menambahkan jeda baris eksplisit, Anda perlu menambahkan tag jeda baris di dalam blok teks Anda. Teks yang mengikutinya akan dimulai pada baris baru.
Mari kita lihat contoh yang sama lagi dengan menambahkan LineBreak menandai.
<TextBlock FontSize = "16">
This is not the end.
<LineBreak/>
It is not even the beginning of the end.
<LineBreak/>
But it is, perhaps, the end of the beginning
</TextBlock>
Ketika kode di atas dijalankan, Anda akan melihat bahwa sekarang terlihat seperti yang ditentukan dalam XAML.
Font Bawaan
Silverlight memiliki satu set keluarga font bawaan yang tetap. Font sebenarnya memiliki nama keluarga yang berbeda karena alasan historis. Keluarga default secara teknis berbeda pada Mac OS dan windows seperti pada Mac OS adalah Lucida Grande, sedangkan pada Windows hampir identik tetapi bernama Lucida Sans Unicode.
Beberapa font yang paling umum digunakan diberikan di bawah ini.
Font |
---|
Arial |
Arial Black |
Comic Sans MS |
Kurir Baru |
Georgia |
Lucida Grande (Mac) atau Lucida Sans Unicode (Windows) |
Times New Roman |
Trebuchet MS |
Verdana |