主にMVVMパターンを維持することに関心がある人のために、私はAndreasGrechの回答を使用して回避策を作成しました。
基本的な流れ:
ユーザーがアイテムをダブルクリック->コードビハインドのイベントハンドラー->ビューモデルのICommand
ProjectView.xaml:
<UserControl.Resources>
<Style TargetType="ListViewItem" x:Key="listViewDoubleClick">
<EventSetter Event="MouseDoubleClick" Handler="ListViewItem_MouseDoubleClick"/>
</Style>
</UserControl.Resources>
...
<ListView ItemsSource="{Binding Projects}"
ItemContainerStyle="{StaticResource listViewDoubleClick}"/>
ProjectView.xaml.cs:
public partial class ProjectView : UserControl
{
public ProjectView()
{
InitializeComponent();
}
private void ListViewItem_MouseDoubleClick(object sender, MouseButtonEventArgs e)
{
((ProjectViewModel)DataContext)
.ProjectClick.Execute(((ListViewItem)sender).Content);
}
}
ProjectViewModel.cs:
public class ProjectViewModel
{
public ObservableCollection<Project> Projects { get; set; } =
new ObservableCollection<Project>();
public ProjectViewModel()
{
}
public ICommand ProjectClick
{
get { return new DelegateCommand(new Action<object>(OpenProjectInfo)); }
}
private void OpenProjectInfo(object _project)
{
ProjectDetailView project = new ProjectDetailView((Project)_project);
project.ShowDialog();
}
}
DelegateCommand.csはここにあります。
私の例では、私はのコレクションを持っています Project
オブジェクトのます。ListView
。これらのオブジェクトには、リストに表示されているよりも多くのプロパティが含まれているため、ProjectDetailView
(WPF Window
)を開いて表示します。
sender
イベントハンドラーのオブジェクトは選択されていListViewItem
ます。その後、Project
アクセスしたいものがContent
プロパティ内に含まれます。