This article is currently in the process of being translated into Italian (~95% done).
Creating a FlowDocument from Code-behind
Finora, abbiamo creato i nostri FlowDocument direttamente in XAML. Rappresentare un documento in XAML ha senso, perché XAML è molto simile all'HTML, che è utilizzato su Internet per creare pagine di informazioni. Tuttavia, questo ovviamente non significa che non è possibile creare FlowDocument da Code-behind. Questò è possibile poiché di ogni elemento, rappresentato da una classe, è possibile creare un'istanza tramite codice C#.
Come piccolo esempio, ecco l'esempio "Hello, world!" creato da Code-behind anziché XAML:
<Window x:Class="WpfTutorialSamples.Rich_text_controls.CodeBehindFlowDocumentSample"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="CodeBehindFlowDocumentSample" Height="200" Width="300">
<Grid>
<FlowDocumentScrollViewer Name="fdViewer" />
</Grid>
</Window>
using System;
using System.Windows;
using System.Windows.Documents;
using System.Windows.Media;
namespace WpfTutorialSamples.Rich_text_controls
{
public partial class CodeBehindFlowDocumentSample : Window
{
public CodeBehindFlowDocumentSample()
{
InitializeComponent();
FlowDocument doc = new FlowDocument();
Paragraph p = new Paragraph(new Run("Hello, world!"));
p.FontSize = 36;
doc.Blocks.Add(p);
p = new Paragraph(new Run("The ultimate programming greeting!"));
p.FontSize = 14;
p.FontStyle = FontStyles.Italic;
p.TextAlignment = TextAlignment.Left;
p.Foreground = Brushes.Gray;
doc.Blocks.Add(p);
fdViewer.Document = doc;
}
}
}
Di seguito il codice XAML richiesta per ottenere esattamente la stessa cosa:
<FlowDocument>
<Paragraph FontSize="36">Hello, world!</Paragraph>
<Paragraph FontStyle="Italic" TextAlignment="Left" FontSize="14" Foreground="Gray">The ultimate programming greeting!</Paragraph>
</FlowDocument>
A volte ha più senso gestire le cose da Code-behind e, come si può vedere, è sicuramente possibile.