在 `ChatDataModel.cs` 中添加了控件引用并重命名消息类型属性。 在 `TrayIconManager.cs` 中将菜单项文本翻译为中文并注释掉部分代码。 调整 `LoginWindow.xaml` 的窗口尺寸。 在 `MainWindow.xaml` 中添加了 `x:Name` 属性和数据触发器,改善了用户体验。 在 `MainWindow.xaml.cs` 中添加了用户登录时的欢迎消息逻辑,并统一了消息类型属性名称。
153 lines
11 KiB
XML
153 lines
11 KiB
XML
<Window
|
||
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"
|
||
xmlns:materialDesign="http://materialdesigninxaml.net/winfx/xaml/themes"
|
||
xmlns:local="clr-namespace:chatclient"
|
||
xmlns:mah="http://metro.mahapps.com/winfx/xaml/controls" x:Class="chatclient.MainWindow"
|
||
mc:Ignorable="d"
|
||
Title="ChatWindow" Height="450" Width="800" MinHeight="240" MinWidth="380"
|
||
Style="{StaticResource MaterialDesignWindow}" Closed="MainWindow_Closed" Loaded="MainWindow_Loaded">
|
||
<Grid>
|
||
<materialDesign:Card>
|
||
<TabControl VerticalContentAlignment="Bottom" materialDesign:ColorZoneAssist.Mode="PrimaryMid" Style="{StaticResource MaterialDesignNavigationRailTabControl}">
|
||
<materialDesign:NavigationRailAssist.FloatingContent>
|
||
<StackPanel>
|
||
<Button Style="{StaticResource MaterialDesignFloatingActionMiniLightButton}" Margin="12">
|
||
<Image Source="/resource/user.png" />
|
||
</Button>
|
||
<TextBlock Text="{Binding UserName}" TextAlignment="Center" MaxWidth="64" MaxHeight="64" TextWrapping="Wrap"/>
|
||
</StackPanel>
|
||
</materialDesign:NavigationRailAssist.FloatingContent>
|
||
<TabItem>
|
||
<TabItem.Header>
|
||
<StackPanel Width="auto" Height="auto">
|
||
<materialDesign:PackIcon Width="24" Height="24" HorizontalAlignment="Center" Kind="Message" />
|
||
<TextBlock HorizontalAlignment="Center" Text="消息" />
|
||
</StackPanel>
|
||
</TabItem.Header>
|
||
<Grid>
|
||
<Grid>
|
||
<Grid.RowDefinitions>
|
||
<RowDefinition Height="Auto"/>
|
||
<!-- 标题栏 -->
|
||
<RowDefinition Height="*"/>
|
||
<!-- 消息区域 -->
|
||
<RowDefinition Height="Auto"/>
|
||
<!-- 输入区域 -->
|
||
</Grid.RowDefinitions>
|
||
|
||
<!-- 标题栏 -->
|
||
<materialDesign:Card Grid.Row="0" Padding="10" Margin="0,0,0,5">
|
||
<StackPanel Orientation="Horizontal">
|
||
<TextBlock Text="聊天室" FontSize="16" FontWeight="Bold"
|
||
VerticalAlignment="Center" Margin="5,0" Cursor="Hand"/>
|
||
<!--<Button x:Name="btnRefresh" Style="{StaticResource MaterialDesignIconButton}"
|
||
ToolTip="刷新列表" Click="RefreshContacts_Click" Margin="5,0,10,0">
|
||
<materialDesign:PackIcon Kind="Refresh"/>
|
||
</Button>-->
|
||
<!--<ComboBox x:Name="cmbContacts" Width="150" Margin="5,0"
|
||
materialDesign:HintAssist.Hint="选择联系人"
|
||
DisplayMemberPath="DisplayName"/>-->
|
||
</StackPanel>
|
||
</materialDesign:Card>
|
||
|
||
<!-- 消息区域 -->
|
||
<ScrollViewer x:Name="messageScroller" Grid.Row="1" VerticalScrollBarVisibility="Auto"
|
||
Padding="10" Background="{DynamicResource MaterialDesignPaper}">
|
||
<ItemsControl x:Name="messageList">
|
||
<ItemsControl.ItemTemplate>
|
||
<DataTemplate>
|
||
<Grid HorizontalAlignment="{Binding Alignment}" Margin="0,5">
|
||
<Grid.ColumnDefinitions>
|
||
<!-- 左侧列:头像或空白 -->
|
||
<ColumnDefinition Width="Auto"/>
|
||
<!-- 中间列:消息卡片 -->
|
||
<ColumnDefinition Width="*"/>
|
||
<!-- 右侧列:头像或空白 -->
|
||
<ColumnDefinition Width="Auto"/>
|
||
</Grid.ColumnDefinitions>
|
||
<!-- 左侧头像(仅当Alignment=Left时显示) -->
|
||
<Border x:Name="leftAvatar" Grid.Column="0" Width="40" Height="40" Margin="10,0,5,0" CornerRadius="20" VerticalAlignment="Top">
|
||
<!-- 图片头像 -->
|
||
<Image Source="{Binding Image}" Stretch="UniformToFill" HorizontalAlignment="Center" VerticalAlignment="Center">
|
||
<Image.Clip>
|
||
<EllipseGeometry Center="20,20" RadiusX="20" RadiusY="20"/>
|
||
</Image.Clip>
|
||
</Image>
|
||
</Border>
|
||
<!-- 消息卡片(始终在中间列) -->
|
||
<materialDesign:Card Grid.Column="1" Padding="10" HorizontalAlignment="{Binding Alignment}">
|
||
<StackPanel>
|
||
<TextBlock Text="{Binding Sender}" x:Name="Sender" FontWeight="Bold" Foreground="{Binding SenderColor}"/>
|
||
<TextBlock Text="{Binding Content}" TextWrapping="Wrap" Margin="0,5,0,0"/>
|
||
<TextBlock Text="{Binding Timestamp, StringFormat='HH:mm:ss'}" x:Name="Timestamp" Foreground="Gray" FontSize="10" HorizontalAlignment="Right" Margin="0,5,0,0"/>
|
||
</StackPanel>
|
||
</materialDesign:Card>
|
||
<!-- 右侧头像(仅当Alignment=Right时显示) -->
|
||
<Border x:Name="rightAvatar" Grid.Column="2" Width="40" Height="40" Margin="5,0,10,0" CornerRadius="20" VerticalAlignment="Top">
|
||
<Image Source="{Binding Image}" Stretch="UniformToFill" HorizontalAlignment="Center" VerticalAlignment="Center">
|
||
<Image.Clip>
|
||
<EllipseGeometry Center="20,20" RadiusX="20" RadiusY="20"/>
|
||
</Image.Clip>
|
||
</Image>
|
||
</Border>
|
||
</Grid>
|
||
<!-- 根据Alignment显示正确的头像 -->
|
||
<DataTemplate.Triggers>
|
||
<DataTrigger Binding="{Binding MsgType}" Value="3">
|
||
<Setter TargetName="Sender" Property="Visibility" Value="Collapsed"/>
|
||
<Setter TargetName="Timestamp" Property="Visibility" Value="Collapsed"/>
|
||
<Setter TargetName="leftAvatar" Property="Visibility" Value="Collapsed"/>
|
||
<Setter TargetName="rightAvatar" Property="Visibility" Value="Collapsed"/>
|
||
</DataTrigger>
|
||
<!-- 左对齐消息:显示左侧头像 -->
|
||
<DataTrigger Binding="{Binding Alignment}" Value="Left">
|
||
<Setter TargetName="leftAvatar" Property="Visibility" Value="Visible"/>
|
||
<Setter TargetName="rightAvatar" Property="Visibility" Value="Collapsed"/>
|
||
</DataTrigger>
|
||
<!-- 右对齐消息:显示右侧头像 -->
|
||
<DataTrigger Binding="{Binding Alignment}" Value="Right">
|
||
<Setter TargetName="leftAvatar" Property="Visibility" Value="Collapsed"/>
|
||
<Setter TargetName="rightAvatar" Property="Visibility" Value="Visible"/>
|
||
</DataTrigger>
|
||
</DataTemplate.Triggers>
|
||
</DataTemplate>
|
||
</ItemsControl.ItemTemplate>
|
||
</ItemsControl>
|
||
</ScrollViewer>
|
||
|
||
<materialDesign:Card materialDesign:ElevationAssist.Elevation="Dp8" Grid.Row="2">
|
||
<Grid Margin="5,0,5,0">
|
||
<Grid.RowDefinitions>
|
||
<RowDefinition Height="*"/>
|
||
<RowDefinition Height="Auto"/>
|
||
</Grid.RowDefinitions>
|
||
<TextBox x:Name="txtMessage" Grid.Row="0" materialDesign:HintAssist.Hint="输入消息..." AcceptsReturn="True" VerticalScrollBarVisibility="Auto"
|
||
TextWrapping="Wrap" MinHeight="50" MaxHeight="100" Margin="5" BorderBrush="#00000000" CaretBrush="#00673AB7" SelectionBrush="#00B39DDB"/>
|
||
<Button x:Name="btnSend" Grid.Row="1" Content="发送" MinWidth="80" Style="{StaticResource MaterialDesignRaisedButton}"
|
||
Click="SendMessage_Click" Width="20" HorizontalAlignment="Right" Margin="2,2,4,4"/>
|
||
</Grid>
|
||
</materialDesign:Card>
|
||
</Grid>
|
||
</Grid>
|
||
</TabItem>
|
||
<TabItem>
|
||
<TabItem.Header>
|
||
<StackPanel Width="auto" Height="auto">
|
||
<materialDesign:PackIcon Width="24" Height="24" HorizontalAlignment="Center" Kind="Cog" />
|
||
<TextBlock HorizontalAlignment="Center" Text="设置" />
|
||
</StackPanel>
|
||
</TabItem.Header>
|
||
<StackPanel>
|
||
<TextBlock Text="这里没有东西..."/>
|
||
</StackPanel>
|
||
</TabItem>
|
||
</TabControl>
|
||
</materialDesign:Card>
|
||
<!--信息框-->
|
||
<materialDesign:Snackbar x:Name="SnackbarThree" MessageQueue="{materialDesign:MessageQueue}" />
|
||
</Grid>
|
||
</Window>
|