0

リストボックスを使用して、選択した値がオブジェクトに適用されて保存される数値のリストを表示しています。リストボックスの高さを1行を表示するのに十分な高さに設定するという考えがありました。もちろん、これにより垂直スクロールバーが表示され、スクロール本体がなくなります。これはまさに私が探していたものです。

リスト ボックスのスクロールバーで上下の矢印をクリックすると、次の項目が正しく表示されます。ただし、アイテムは選択されていません。表示されている値ではなく、実際に選択された値が保存されるという問題がすぐに発生しました。これは、実際に値を選択するには、スクロールバー ボタンの後の数字をクリックする必要があり、あまり直感的ではないためです。

そのため、いくつかのインテルセンスハンティングの後、リストボックスのスクロールバーボタンをクリックして選択した値をインクリメントする方法を探し始めましたが、実際にそれらを使用するものは見つかりません.

スクロール バーの本体をクリックしたときのアクションを説明する投稿や、デザイナーが追加したボタンを使用してリスト ボックスのインデックスを変更する投稿を見つけました。ただし、リスト ボックスの高さが短いため、スクロール バーの本体は表示されません。これら 2 つのボタンが既に利用可能で、ほとんどの作業を行っている場合に、さらにボタンを追加するのはばかげているようです。

同様のことを説明している投稿も見つけましたが、リストビューを使用しています。しかし、この時点で、現在使用しているコントロールのどこかで利用できるはずだと本当に思う機能のためにコントロールを交換する必要はありません。

だから、私が探しているのは、リストボックスコントロールの垂直スクロールバーボタンのクリックイベントハンドラーに対処する方法だと思います。

どんな助けでも大歓迎です。(ここで解決するために投稿する必要のなかった他の1000のことをありがとう!)

4

1 に答える 1

0

そのフィルとあなたの権利について聞いたことがあります。数値のアップダウンの置き換えを行っています。

その特定のコントロールはもともとフレームワークの一部ではなかったので、おそらく実行可能な代替手段があると思いました。また、私はそれの多くが機能しており、結果とテーマを取り上げる方法が本当に気に入っています.

このアプリケーションのコアは将来のアプリケーションの出発点になるため、この機能を含めたいと考え、そのために少し作業を行う準備ができていました。

私がやったことは少し複雑でしたが、便利なヘルパー関数で簡単になりました。ターゲット タイプの「ビジュアル ツリー」を検索する必要がありました。そこから、仕上げるのに十分な機能にアクセスできました。

最初:ここで見つけたヘルパー関数を使用して(Bruno に感謝)、これを Loaded イベントに追加することができました。

private Double currentVerticalOffset;
private void Page_Loaded_1(object sender, RoutedEventArgs e)
    {            
        ScrollViewer sv = Helpers.ViewHelpers.ListBoxHelper.FindVisualChild<ScrollViewer>(listbox);
        sv.ScrollChanged += HandleRankScrollChange;
        currentVerticalOffset = sv.VerticalOffset;
    }

次に、スクロール変更イベントを処理します。

private void HandleRankScrollChange(object sender, ScrollChangedEventArgs e)
    {
        ScrollViewer sv = Helpers.ViewHelpers.ListBoxHelper.FindVisualChild<ScrollViewer>(listbox);

        if (sv.VerticalOffset > currentVerticalOffset)
        {
            Helpers.ViewHelpers.ListBoxHelper.SelectNextItem(listbox);
        }

        if (sv.VerticalOffset < currentVerticalOffset)
        {
            Helpers.ViewHelpers.ListBoxHelper.SelectPreviousItem(listbox);
        }
        currentVerticalOffset = sv.VerticalOffset;
    }

ここで呼び出すヘルパーは非常に単純ですが、これも基本キットになるので、メソッドがあると再び便利になるでしょう。

public static void SelectNextItem(ListBox lb)
    {
        if (lb.SelectedIndex < lb.Items.Count)
        {
            lb.SelectedIndex++;
        }
    }

    public static void SelectPreviousItem(ListBox lb)
    {
        if (lb.SelectedIndex > 0)
        {
            lb.SelectedIndex--;
        }
    }

ブルーノのヘルパー関数

public static childItem FindVisualChild<childItem>(DependencyObject obj) where childItem : DependencyObject
    {
        for (int i = 0; i < VisualTreeHelper.GetChildrenCount(obj); i++)
        {
            DependencyObject child = VisualTreeHelper.GetChild(obj, i);
            if (child != null && child is childItem)
            {
                return (childItem)child;
            }
            else
            {
                childItem childOfChild = FindVisualChild<childItem>(child);
                if (childOfChild != null)
                {
                    return childOfChild;
                }
            }
        }
        return null;
    }

再度、感謝します。

于 2013-04-07T01:31:53.487 に答える