123

ここには、さまざまな言語について議論されている多数の隠れた機能があります。XAML と WPF の隠れた機能に興味がありますか?

私が見つけたのは、ListViewのヘッダークリックイベントです

<ListView x:Name='lv' 
      Height="150" 
      GridViewColumnHeader.Click="GridViewColumnHeaderClickedHandler">

GridViewColumnHeader.Click プロパティは表示されません。

これまでの関連機能の一部:

以下も参照してください。

  1. C# の隠れた機能
  2. Python の隠れた機能
  3. ASP.NET の隠れた機能
  4. Perl の隠れた機能
  5. Java の隠れた機能
  6. VB.NET の隠れた機能
  7. PHPの隠れた機能
  8. Ruby の隠れた機能
  9. C の隠れた機能
  10. 等々........
4

25 に答える 25

87

マルチバインディング ( StringFormatとの組み合わせ):

<TextBlock>
  <TextBlock.Text>
    <MultiBinding StringFormat="{}{0}, {1}">
      <Binding Path="LastName" />
      <Binding Path="FirstName" />
    </MultiBinding>
  </TextBlock.Text>
</TextBlock>
于 2009-07-14T13:54:57.177 に答える
58

特定のシナリオでバインディングで何が起こっているかをデバッグする PresentationTraceSources.TraceLevel トリックもあります。WindowsBase アセンブリで System.Diagnostics 名前空間を参照するだけです。

xmlns:sd="clr-namespace:System.Diagnostics;assembly=WindowsBase"

次に、バインディング式に次を追加します。

<TextBlock Text="{Binding Message, sd:PresentationTraceSources.TraceLevel=High}"  />

ログは次のようになります。

System.Windows.Data Warning: 52 : Created BindingExpression (hash=5923895) for Binding (hash=7588182)
System.Windows.Data Warning: 54 :   Path: 'Message'
System.Windows.Data Warning: 56 : BindingExpression (hash=5923895): Default mode resolved to OneWay
System.Windows.Data Warning: 57 : BindingExpression (hash=5923895): Default update trigger resolved to PropertyChanged
System.Windows.Data Warning: 58 : BindingExpression (hash=5923895): Attach to System.Windows.Controls.TextBlock.Text (hash=65248697)
System.Windows.Data Warning: 63 : BindingExpression (hash=5923895): Resolving source 
于 2009-07-14T14:15:22.157 に答える
44

3.5sp1はStringFormatをバインディング式に導入しました。

<TextBox Text="{Binding Date, StringFormat='{}{0:MM/dd/yyyy}'}" />
于 2009-07-14T13:50:06.213 に答える
44

3.5sp1 では、バインディングに TargetNullValue が導入されました。これにより、値が入力された場合はバインドされたプロパティが Null に設定され、プロパティが Null の場合はこの値が表示されます。

<TextBox Text="{Binding Total, TargetNullValue=$0.00}" />
于 2009-07-14T14:02:57.213 に答える
29

ラベルに表示するには長すぎる文字列が表示されることがあります。この場合、 のTextTrimmingプロパティを利用TextBlockして楕円を表示できます

<TextBlock 
  Name="sampleTextBlock" 
  TextTrimming="WordEllipsis" 
  TextWrapping="NoWrap"/>

MSDN リンク

于 2009-09-07T12:25:41.450 に答える
27

ウィンドウにエアロエフェクトを追加する

  <Window.Resources>
    <ResourceDictionary Source="/PresentationFramework.Aero, Version=3.0.0.0, Culture=neutral, 
        PublicKeyToken=31bf3856ad364e35, ProcessorArchitecture=MSIL;component/themes/aero.normalcolor.xaml" />
</Window.Resources>
于 2009-08-24T13:14:28.293 に答える
21

x:TypeArguments を使用した XAML のジェネリック

XAML で ObservableCollection を使用する場合は、XAML で宣言できないため、ObservableCollection から派生した型を作成する必要があります。XAML 2009 では、x:TypeArguments 属性を使用してジェネリック型の型を定義できます。

<!-- XAML 2006 -->
class EmployeeCollection : ObservableCollection<Employee>
{
}

<l:EmployeeCollection>
    <l:Employee FirstName="John" Name="Doe" />
    <l:Employee FirstName="Tim" Name="Smith" />
</lEmployeeCollection>

<!-- XAML 2009 -->
<ObservableCollection x:TypeArguments="Employee">
    <l:Employee FirstName="John" Name="Doe" />
    <l:Employee FirstName="Tim" Name="Smith" />
</ObservableCollection />
于 2009-09-10T12:16:37.810 に答える
19

x:Arguments でのデフォルト以外のコンストラクターの使用

XAML 2006 では、オブジェクトを使用するには、パブリックの既定のコンストラクターが必要です。XAML 2009 では、x:Arguments 構文を使用してコンストラクター引数を渡すことができます。

<!-- XAML 2006 -->
<DateTime>00:00:00.0000100</DateTime>

<!-- XAML 2009 -->
<DateTime>
    <x:Arguments>
        <x:Int64>100</x:Int64>
    </x:Arguments>
</DateTime>
于 2009-09-10T12:12:42.537 に答える
19

無効なコントロールにツールチップを表示する

Wpf では、コントロールが無効な状態の場合、コントロールにツールチップを表示できます。

例えば

<Button Content="Disabled Button" ToolTipService.ShowOnDisabled="True" IsEnabled="False" ToolTip="This is a disabled button"/> 
于 2009-09-10T05:04:43.640 に答える
18

実際には隠された機能ではありませんが、WPF/XAML を使用するとBea StollnitzJosh Smithが得られます。WPF/XAML プログラミングの女王と王。

于 2009-07-14T14:33:46.043 に答える
18

マークアップ拡張機能と添付プロパティは私のお気に入りの機能です。これらを使用すると、XAML の "語彙" を非常に洗練された方法で拡張できます。

マークアップ拡張機能

<!-- Binding to app settings -->
<CheckBox IsChecked="{my:SettingBinding MinimizeToTray}">Close to tray</CheckBox>

<!-- Fill ItemsControl with the values of an enum -->
<ComboBox ItemsSource="{my:EnumValues sys:DaysOfWeek}"/>

<!-- Localization -->
<TextBlock Text="{my:Localize HelloWorld.Text}"/>

<!-- Switch on the result of a binding -->
<TextBlock Text="{my:Switch Path=IsGood, ValueIfTrue=Good, ValueIfFalse=Bad}"/>

添付プロパティ

<!-- Sort GridView automatically -->
<ListView ItemsSource="{Binding Persons}"
      IsSynchronizedWithCurrentItem="True"
      util:GridViewSort.AutoSort="True">
    <ListView.View>
        <GridView>
            <GridView.Columns>
                <GridViewColumn Header="Name"
                                DisplayMemberBinding="{Binding Name}"
                                util:GridViewSort.PropertyName="Name"/>
                <GridViewColumn Header="First name"
                                DisplayMemberBinding="{Binding FirstName}"
                                util:GridViewSort.PropertyName="FirstName"/>
                <GridViewColumn Header="Date of birth"
                                DisplayMemberBinding="{Binding DateOfBirth}"
                                util:GridViewSort.PropertyName="DateOfBirth"/>
            </GridView.Columns>
        </GridView>
    </ListView.View>
</ListView>


<!-- Vista Glass effect -->
<Window x:Class="WpfApplication1.Window1"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:my="clr-namespace:WpfApplication1"
        Title="Window1"
        my:WinUtil.EnableAeroGlass="True">

...

GridViewSortのソース(ところで、Ortus がGridViewColumnHeader.Click言及したイベントを使用します)

于 2009-08-24T12:29:20.373 に答える
15

プラス記号 ( +) を使用して、入れ子になった型を XAML で参照できます。たとえば、次のクラスがあるとします。

public class SomeClass
{
    public enum SomeEnum
    {
        SomeValue
    };
}

SomeValue次の構文を使用して XAML で参照できます。

{x:Static local:SomeClass+SomeEnum.SomeValue}

この構文はMSDNで文書化されておらず、公式にはサポートされていません。誰かが MSDN フォーラムで質問したところ、VS2010 の WPF デザイナーが壊れているようです。Microsoft Connect で報告されています。

于 2011-01-12T19:08:05.337 に答える
14

グリッド サイズの共有 (これが良い例です)。簡単に言えば、異なるグリッド間であっても、グリッドの列と行にサイズを共有させることができます。これは、データをその場で編集する必要なく DataGrid を使用しているすべての人にとって非常に貴重です。

于 2009-07-14T14:07:39.000 に答える
11

PriorityBinding。「先着順」の順序でasynバインディングを使用できます。

<TextBlock.Text>
      <PriorityBinding FallbackValue="defaultvalue">
        <Binding Path="SlowestDP" IsAsync="True"/>
        <Binding Path="SlowerDP" IsAsync="True"/>
        <Binding Path="FastDP" />
      </PriorityBinding>
</TextBlock.Text>
于 2010-03-05T21:27:45.127 に答える
10

x:FactoryMethod での静的ファクトリ メソッドの使用

パブリック コンストラクターを持たず、静的ファクトリ メソッドを持つ型がある場合、XAML 2006 のコードでその型を作成する必要がありました。XAML 2009 では、 x:FactoryMethodx:Arguments 属性を使用して引数値を渡すことができます。

<!-- XAML 2006 -->
Guid id = Guid.NewGuid();

<!-- XAML 2009 -->
<Guid x:FactoryMethod="Guid.NewGuid" />
于 2009-09-10T12:01:44.073 に答える
7

高度な「キャプション」プロパティ

もう 1 つはっきりしていないのは、テキストしか含まれていない一部のプロパティの内容です。GUI 要素のプロパティが Object 型の場合、テキストを設定するだけでなく、一連のコントロールを含む必要なパネルを追加できる可能性が非常に高くなります。

この例は MenuItem で、Headerプロパティ (通常はテキストのみを含む) に、パネル コントロールにラップされた一連の gui 要素 (または 1 つだけが必要な場合は 1 つの gui 要素) を含めることができます。

Iconまた、MenuItemのプロパティにも注意してください。通常、これには Image 要素が含まれますが、何でも含めることができます。

<MenuItem Name="MyMenuItem" Click="MyMenuItem_Click">
  <MenuItem.Icon>
    <Button Click="Button1_Click">i</Button>
  </MenuItem.Icon>
  <MenuItem.Header>
     <StackPanel Orientation="Horizontal" >
        <Label>My text</Label>
        <Button Click="Button2_Click">ClickMe!</Button>
     </StackPanel>
  </MenuItem.Header>
</MenuItem>
于 2009-07-22T11:06:58.320 に答える
6

組み込み型

現在、string や double などの単純な型のオブジェクトをリソース ディクショナリに追加する場合は、必要な clr-namespace を XML 名前空間にマップする必要があります。XAML 2009 では、XAML 言語に多くの単純型が含まれています。

<!-- XAML 2006 -->
<sys:String xmlns:sys="clr-namespace:System;assembly=mscorlib >Test</sys:String>

<!-- XAML 2009 -->
<x:String>Test</x:String>

次の型が XAML 言語に含まれています。

<x:Object/> 
<x:Boolean/> 
<x:Char/> 
<x:String/> 
<x:Decimal/> 
<x:Single/> 
<x:Double/> 
<x:Int16/> 
<x:Int32/> 
<x:Int64/> 
<x:TimeSpan/> 
<x:Uri/> 
<x:Byte/> 
<x:Array/> 
<x:List/> 
<x:Dictionary/> 
于 2009-09-10T11:59:51.957 に答える
6

{x:Reference} による簡単なオブジェクト参照

今日オブジェクト参照を作成したい場合は、データバインディングを行い、ElementName でソースを宣言する必要があります。XAML 2009 では、新しい {x:Reference} マークアップ拡張機能を使用できます

<!-- XAML 2006 -->
<Label Target="{Binding ElementName=firstName}">FirstName</Label>
<TextBox x:Name="firstName" />

<!-- XAML 2009 -->
<Label Target="{x:Reference firstName}">FirstName</Label>
<TextBox x:Name="firstName" />
于 2009-09-10T12:09:04.617 に答える
6

システム カラーの使用

<Border Background="{DynamicResource {x:Static SystemColors.InactiveBorderBrushKey}}"/>
于 2010-06-15T04:20:17.303 に答える
3

任意の辞書キーのサポート

XAML 2006 では、明示的な x:Key 値はすべて文字列として扱われました。XAML 2009 では、ElementSyntax にキーを記述することで、好きなタイプのキーを定義できます。

<!-- XAML 2006 -->
<StreamGeometry x:Key="CheckGeometry">M 0 0 L 12 8 l 9 12 z</StreamGeometry>

<!-- XAML 2009 -->
<StreamGeometry>M 0 0 L 12 8 l 9 12 z
    <x:Key><x:Double>10.0</x:Double></x:Key>
</StreamGeometry>
于 2009-09-10T12:03:56.440 に答える
2

UIElement を TextBlock に詰め込む機能

これがどれほど便利かはわかりませんが(ただし、非表示と見なされます)、これが...しかし、最初に遭遇したときは確かに不意を突かれました

<Grid x:Name="LayoutRoot">
    <TextBlock HorizontalAlignment="Center" VerticalAlignment="Center">
        <Grid>
            <Rectangle Fill="AliceBlue" Width="25" Height="25"/>
        </Grid>
    </TextBlock>
</Grid>

次の xaml が役立つ可能性があると主張することができます (つまり、テキストの最後にグラフィックを配置します)。

<Grid>
    <TextBlock HorizontalAlignment="Center" VerticalAlignment="Center" Text="Hello World">
        <TextBlock.Resources>
            <DrawingBrush x:Key="exclamationPoint" Stretch="Uniform">
                <DrawingBrush.Drawing>
                    <DrawingGroup>
                        <DrawingGroup.Children>
                            <GeometryDrawing Brush="#FF375CE2" Geometry="F1 M 7.968,58.164L 0,58.164L 1.914,49.921L 9.882,49.921L 7.968,58.164 Z M 21.796,0L 11.054,42.148L 4.403,42.148L 13.049,0L 21.796,0 Z "/>
                        </DrawingGroup.Children>
                    </DrawingGroup>
                </DrawingBrush.Drawing>
            </DrawingBrush>
        </TextBlock.Resources>
        <Grid>
            <Rectangle Width="100" Height="100" Fill="{StaticResource exclamationPoint}"/>
        </Grid>
    </TextBlock>
</Grid>

上記の xaml は次のようにレンダリングされます。

こんにちは世界

于 2011-01-12T22:18:20.153 に答える
2

コードで ValidationError を設定する

BindingExpression の ValidatioRule は、バインディングのターゲット側が変更された場合にのみトリガーされます。コードで検証エラーを設定する場合は、次のスニペットを使用できます。

検証エラーを設定する

ValidationError validationError = 
    new ValidationError(regexValidationRule, 
    textBox.GetBindingExpression(TextBox.TextProperty));

validationError.ErrorContent = "This is not a valid e-mail address";

Validation.MarkInvalid(
    textBox.GetBindingExpression(TextBox.TextProperty), 
    validationError);

検証エラーをクリアする

Validation.ClearInvalid(textBox.GetBindingExpression(TextBox.TextProperty));
于 2009-09-10T12:21:04.753 に答える
1

INotifyPropertyChangedまたはDependencyPropertiesを使用しないバインディング

ここで説明するように、INotifyPropertyChangedなしでプレーンCLRオブジェクトプロパティをバインドでき、それは正常に機能します。

これが私が言及しているフォーラムポストです。

引用:

[...] WPFのデータバインディングエンジンは、ソースオブジェクトがプレーンCLRオブジェクトであり、INotifyPropertyChangedインターフェイスを実装していない場合に、ソースプロパティをラップするPropertyDescriptorインスタンスにデータバインドします。また、データバインディングエンジンは、PropertyDescriptor.AddValueChanged()メソッドを介してプロパティ変更イベントをサブスクライブしようとします。また、ターゲットデータバインド要素がプロパティ値を変更すると、データバインディングエンジンはPropertyDescriptor.SetValue()メソッドを呼び出して変更された値をソースプロパティに転送し、同時にValueChangedイベントを発生させて他のサブスクライバー(この場合は他のサブスクライバーは、ListBox内のTextBlocksになります。

また、INotifyPropertyChangedを実装している場合は、UIにデータバインドする必要があるプロパティのすべてのセッターに変更通知を実装する責任があります。そうしないと、変更が期待どおりに同期されません。[...]

これは、このテーマに関するもう1つのすばらしい詳細な記事です。

これは、バインディングを使用する場合にのみ機能することに注意してください。コードから値を更新した場合、変更は通知されません。[...]

INotifyPropertyChangedの実装は、かなり面倒な開発作業になる可能性があります。ただし、その作業とWPFアプリケーションの実行時のフットプリント(メモリとCPU)を比較検討する必要があります。INPCを自分で実装すると、ランタイムCPUとメモリを節約できます

于 2011-10-14T12:11:29.020 に答える
1

アニメーションのデバッグ

一般的なエラー

次のエラーが発生した場合: 不変オブジェクト インスタンスで '(0).(1)' をアニメーション化できません。次の制限のいずれかに遭遇している可能性があります。

  • ローカル値を設定せずに依存関係プロパティをアニメーション化しています
  • リソース ディクショナリにマージされていない別のアセンブリで現在の値が定義されている依存関係プロパティをアニメーション化しています。
  • 現在データバインドされている値をアニメーション化しています
于 2009-09-10T12:41:18.593 に答える