相关面板/网格无法对齐项目模板选择器中的水平对齐方式
relative panel / grid cannot align the horizontal alignment in item template selector
我正在开发一个聊天应用程序。聊天页面由一个 itemTemplateSelector 组成,它通过检查 bool 值根据发件人将文本对齐到右 end/left 结尾。这是代码
<Page.Resources>
<DataTemplate x:Key="ChatTemplateR">
<Grid HorizontalAlignment="Stretch">
<StackPanel HorizontalAlignment="Right" >
<Border Background="{ThemeResource SystemControlBackgroundAccentBrush}" >
<TextBlock MinWidth="200" Text="{Binding conversation}" TextWrapping="Wrap" Margin="5"/>
</Border>
<Path x:Name="DownRightTri"
HorizontalAlignment="Right"
Margin="0,0,10,0"
Fill="{ThemeResource SystemControlBackgroundAccentBrush}"
Data="M0,0 H10 V10" />
</StackPanel>
</Grid>
</DataTemplate>
<DataTemplate x:Key="ChatTemplateL">
<Grid HorizontalAlignment="Stretch">
<StackPanel HorizontalAlignment="Left">
<Path x:Name="UpLeftTri"
HorizontalAlignment="Left"
Margin="10,0,0,0"
Fill="{ThemeResource SystemControlBackgroundAccentBrush}"
Data="M0,-5 V5 H10 " />
<Border Background="{ThemeResource SystemControlBackgroundAccentBrush}" >
<TextBlock MinWidth="200" Text="{Binding conversation}" TextWrapping="Wrap" Margin="5"/>
</Border>
</StackPanel>
</Grid>
</DataTemplate>
<local1:ChatTemplateSelector x:Key="ChatSelector" LeftTemplate="{StaticResource ChatTemplateL}" RightTemplate="{StaticResource ChatTemplateR}"/>
</Page.Resources>
<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Grid.RowDefinitions>
<RowDefinition Height="auto"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="auto"/>
<ColumnDefinition Width="*"/>
</Grid.ColumnDefinitions>
<Button x:Name="backButton"
FontFamily="Segoe MDL2 Assets"
Content=""
Foreground="{StaticResource SystemControlBackgroundAccentBrush}"
FontSize="25"
Background="{StaticResource ApplicationPageBackgroundThemeBrush}"
Click="backButton_Click">
<Button.Transitions>
<TransitionCollection>
<EdgeUIThemeTransition Edge="Left"/>
</TransitionCollection>
</Button.Transitions>
</Button>
<TextBlock Text="Chats" Grid.Column="1" Style="{ThemeResource tb1}" HorizontalAlignment="Center"/>
<Grid Grid.Row="1" Grid.Column="0" Grid.ColumnSpan="2">
<Grid.RowDefinitions>
<RowDefinition Height="*"/>
<RowDefinition Height="auto"/>
</Grid.RowDefinitions>
<ListView x:Name="lv" ItemsSource="{Binding BuddyChatOC}" ItemTemplateSelector="{StaticResource ChatSelector}">
</ListView>
<RelativePanel Grid.Row="1" Margin="5,10,5,10">
<TextBox x:Name="sendtext" Margin="0,0,2,0" RelativePanel.AlignLeftWithPanel="True" RelativePanel.LeftOf="sendtextbutton"/>
<Button x:Name="sendtextbutton" Content="Send" Command="{Binding sendChatCommand}" RelativePanel.AlignRightWithPanel="True" >
</Button>
</RelativePanel>
</Grid>
</Grid>
项目模板选择器:
public class ChatTemplateSelector : DataTemplateSelector
{
public DataTemplate LeftTemplate { get; set; }
public DataTemplate RightTemplate { get; set; }
protected override DataTemplate SelectTemplateCore(object item, DependencyObject container)
{
BuddyChat2Datum chat = (BuddyChat2Datum)item;
DataTemplate dt = chat.isLeft ? this.LeftTemplate : this.RightTemplate;
return dt;
}
}
随着聊天框的变化,itemtemplateselector 确实可以正常工作。我无法将 rightSide chatBox 移到右端。有什么建议吗?
只需将 TextAlignment="Right"
添加到正确模板中的 TextBlock
。
您的 ListView 项目可能没有完全伸展...尝试将其添加到 ListView:
<ListView.ItemContainerStyle>
<Style TargetType="ListViewItem">
<Setter Property="HorizontalAlignment" Value="Stretch" />
<Setter Property="HorizontalContentAlignment" Value="Stretch" />
</Style>
</ListView.ItemContainerStyle>
我正在开发一个聊天应用程序。聊天页面由一个 itemTemplateSelector 组成,它通过检查 bool 值根据发件人将文本对齐到右 end/left 结尾。这是代码
<Page.Resources>
<DataTemplate x:Key="ChatTemplateR">
<Grid HorizontalAlignment="Stretch">
<StackPanel HorizontalAlignment="Right" >
<Border Background="{ThemeResource SystemControlBackgroundAccentBrush}" >
<TextBlock MinWidth="200" Text="{Binding conversation}" TextWrapping="Wrap" Margin="5"/>
</Border>
<Path x:Name="DownRightTri"
HorizontalAlignment="Right"
Margin="0,0,10,0"
Fill="{ThemeResource SystemControlBackgroundAccentBrush}"
Data="M0,0 H10 V10" />
</StackPanel>
</Grid>
</DataTemplate>
<DataTemplate x:Key="ChatTemplateL">
<Grid HorizontalAlignment="Stretch">
<StackPanel HorizontalAlignment="Left">
<Path x:Name="UpLeftTri"
HorizontalAlignment="Left"
Margin="10,0,0,0"
Fill="{ThemeResource SystemControlBackgroundAccentBrush}"
Data="M0,-5 V5 H10 " />
<Border Background="{ThemeResource SystemControlBackgroundAccentBrush}" >
<TextBlock MinWidth="200" Text="{Binding conversation}" TextWrapping="Wrap" Margin="5"/>
</Border>
</StackPanel>
</Grid>
</DataTemplate>
<local1:ChatTemplateSelector x:Key="ChatSelector" LeftTemplate="{StaticResource ChatTemplateL}" RightTemplate="{StaticResource ChatTemplateR}"/>
</Page.Resources>
<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Grid.RowDefinitions>
<RowDefinition Height="auto"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="auto"/>
<ColumnDefinition Width="*"/>
</Grid.ColumnDefinitions>
<Button x:Name="backButton"
FontFamily="Segoe MDL2 Assets"
Content=""
Foreground="{StaticResource SystemControlBackgroundAccentBrush}"
FontSize="25"
Background="{StaticResource ApplicationPageBackgroundThemeBrush}"
Click="backButton_Click">
<Button.Transitions>
<TransitionCollection>
<EdgeUIThemeTransition Edge="Left"/>
</TransitionCollection>
</Button.Transitions>
</Button>
<TextBlock Text="Chats" Grid.Column="1" Style="{ThemeResource tb1}" HorizontalAlignment="Center"/>
<Grid Grid.Row="1" Grid.Column="0" Grid.ColumnSpan="2">
<Grid.RowDefinitions>
<RowDefinition Height="*"/>
<RowDefinition Height="auto"/>
</Grid.RowDefinitions>
<ListView x:Name="lv" ItemsSource="{Binding BuddyChatOC}" ItemTemplateSelector="{StaticResource ChatSelector}">
</ListView>
<RelativePanel Grid.Row="1" Margin="5,10,5,10">
<TextBox x:Name="sendtext" Margin="0,0,2,0" RelativePanel.AlignLeftWithPanel="True" RelativePanel.LeftOf="sendtextbutton"/>
<Button x:Name="sendtextbutton" Content="Send" Command="{Binding sendChatCommand}" RelativePanel.AlignRightWithPanel="True" >
</Button>
</RelativePanel>
</Grid>
</Grid>
项目模板选择器:
public class ChatTemplateSelector : DataTemplateSelector
{
public DataTemplate LeftTemplate { get; set; }
public DataTemplate RightTemplate { get; set; }
protected override DataTemplate SelectTemplateCore(object item, DependencyObject container)
{
BuddyChat2Datum chat = (BuddyChat2Datum)item;
DataTemplate dt = chat.isLeft ? this.LeftTemplate : this.RightTemplate;
return dt;
}
}
随着聊天框的变化,itemtemplateselector 确实可以正常工作。我无法将 rightSide chatBox 移到右端。有什么建议吗?
只需将 TextAlignment="Right"
添加到正确模板中的 TextBlock
。
您的 ListView 项目可能没有完全伸展...尝试将其添加到 ListView:
<ListView.ItemContainerStyle>
<Style TargetType="ListViewItem">
<Setter Property="HorizontalAlignment" Value="Stretch" />
<Setter Property="HorizontalContentAlignment" Value="Stretch" />
</Style>
</ListView.ItemContainerStyle>