質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
WPF

Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

Q&A

解決済

1回答

6281閲覧

ListView に ScrollViewer を付け下部に移動した時のインデックスが正しく取得できない

byori

総合スコア71

WPF

Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

1グッド

0クリップ

投稿2020/03/16 02:45

ListView に ScrollViewer タグをつけてスクロールバーを表示させています。スクロールバーを動かしていない時点でクリック(ドラッグアンドドロップの為)すると、正しく選択した位置を返してきます。
private void listView_MouseMove(object sender, MouseEventArgs e)内で取得できています。

ところが、スクロールバーを下げて下部のデータを表示した状態で下の方のデータ(スクロールバーを下げないと表示しない部分)を同じようにクリックするとスクロールバーが戻り(上にズレて先頭からの表示になる)その時点でのインデックスの取得になってしまいます。

スクロールバーを下げた下部データの位置でなくスクロールバーが戻った(初期位置)状態のインデックスになってしまう。

正しいクリックした位置の情報を取得する方法を知りたい。

以下にコードです。長文で申し訳ありません。VS2015 C# WPF

Xaml

1<ScrollViewer Height="485" Width="340"> 2 <StackPanel> 3 <ListView Margin = "0" Name="lvUsers" MouseMove="listView_MouseMove" BorderThickness="1" 4 ItemsSource="{Binding}" > 5 <ListView.Resources> 6 <Style TargetType="{x:Type ListViewItem}"> 7 <Style.Resources> 8 <Style TargetType="{x:Type TextBlock}"> 9 <Setter Property="ToolTip" Value="{Binding RelativeSource={RelativeSource Self}, Path='Text'}" /> 10 <Style.Triggers> 11 <DataTrigger Binding="{Binding ElementName=check3, Path=IsChecked}" Value="True"> 12 <!-- <Setter Property="FontWeight" Value="Bold" /> --> 13 <Setter Property="TextWrapping" Value="Wrap" /> 14 </DataTrigger> 15 </Style.Triggers> 16 </Style> 17 </Style.Resources> 18 </Style> 19 </ListView.Resources> 20 21 <ListView.ItemsPanel> 22 <ItemsPanelTemplate> 23 <StackPanel Orientation="Vertical" HorizontalAlignment="Center" /> 24 </ItemsPanelTemplate> 25 </ListView.ItemsPanel> 26 <ListView.View> 27 <GridView> 28 <GridViewColumn Header = "No" Width="30" DisplayMemberBinding="{Binding No}" /> 29 <GridViewColumn Header = "Name" Width="80" DisplayMemberBinding="{Binding Name}" /> 30 <GridViewColumn Header = "Data" Width="170" DisplayMemberBinding="{Binding Data}" /> 31 </GridView> 32 </ListView.View> 33 </ListView> 34 </StackPanel> 35</ScrollViewer>

ビハインドコード

private void listView_MouseMove(object sender, MouseEventArgs e) { ListView listView = sender as ListView; if (listView != null && e.LeftButton == MouseButtonState.Pressed) { //ドラッグするアイテムのインデックスを取得する int itemIndex = listView.SelectedIndex; if (itemIndex < 0) return; : : } } public class User { public string No { get; set; } public string Name { get; set; } public string Data { get; set; } public User(string _no, string _name,string _data) { No = _no; Name = _name; Data = _data; } public User() { } } // 下記のようなデータが CSV 形式で保存され comment に読み込まれています。 2,No SMT,Note : SMTの所見は認められません。, 3,f-u,Note : Follow up の上、難治性の時は再検して下さい。, 4,f-u 1 - 2,Note : Follow-up の上、1~2ヶ月後に再検して下さい。, 5,f-u 3 - 6,Note : Follow-up の上、3~6ヶ月後に再検して下さい。, 6,f-u 6 - 9,Note : Follow-up の上、6~9ヶ月後に再検して下さい。, 7,Ca なし f-u,Note : 悪性像は見られません。Follow upを!, : : // リストの初期化 List<User> items = new List<User>(); foreach (var txt in comment) { items.Add(new User() { No = txt.No, Name = txt.Name, Data = txt.Data }); } lvUsers.ItemsSource = items;
TN8001👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

ListViewHeightを設定する。
もしくは↓をコメントアウトする。

xml

1<ListView.ItemsPanel> 2 <ItemsPanelTemplate> 3 <StackPanel HorizontalAlignment="Center" Orientation="Vertical" /> 4 </ItemsPanelTemplate> 5</ListView.ItemsPanel>

と上に戻らなくなりました(理由はよくわかりませんでした)

というかこれだと表示がおかしいですよね?(ヘッダーと位置が合わないし、カラムの幅を変えるときの動作も変)


ListView自体にスクロール機能がありますが、ScrollViewerでスクロールさせる事情がありますか?(全体のxamlがわからないと何とも言えませんが)

投稿2020/03/16 08:57

編集2023/07/21 08:48
TN8001

総合スコア9244

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

byori

2020/03/17 00:31

お世話になります。 ListView には、その機能があったんですね。 気づきませんでした。下記でうまくいきました。ありがとうございます。 <ListView ・・・ Height="485" Width="340" ScrollViewer.VerticalScrollBarVisibility="Visible">
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問