3

テキストボックス内に透かしを表示するためにadornerを使用しています。しかし、ウィンドウのFlowDirectionをRightToLeftに設定すると、adorner(テキストブロック)内のテキストが逆になります!!!

それはバグですか、それとも何かを変更する必要がありますか?

ここに画像の説明を入力してください

そしてここに装飾者の完全なコードがあります:

namespace Hezareh.Modules.Accounting  
{
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Data;
    using System.Windows.Documents;
    using System.Windows.Media;


    internal class WatermarkAdorner : Adorner
    {
        #region Private Fields

        private readonly ContentPresenter contentPresenter;

        #endregion

        #region Constructor

        public WatermarkAdorner(UIElement adornedElement, object watermark) :
            base(adornedElement)
        {
            this.IsHitTestVisible = false;
            this.contentPresenter = new ContentPresenter();
            this.contentPresenter.Content = watermark;
            this.contentPresenter.Opacity = 0.5;
            this.contentPresenter.Margin = new Thickness(Control.Margin.Left + Control.Padding.Left, Control.Margin.Top + Control.Padding.Top, 0, 0);
            if (this.Control is ItemsControl && !(this.Control is ComboBox))
            {
                this.contentPresenter.VerticalAlignment = VerticalAlignment.Center;
                this.contentPresenter.HorizontalAlignment = HorizontalAlignment.Center;
            }

            // Hide the control adorner when the adorned element is hidden
            Binding binding = new Binding("IsVisible");
            binding.Source = adornedElement;
            binding.Converter = new BooleanToVisibilityConverter();
            this.SetBinding(VisibilityProperty, binding);
        }

        #endregion

        #region Protected Properties

        protected override int VisualChildrenCount
        {
            get { return 1; }
        }

        #endregion

        #region Private Properties

        private Control Control
        {
            get { return (Control)this.AdornedElement; }
        }

        #endregion

        #region Protected Overrides

        protected override Visual GetVisualChild(int index)
        {
            return this.contentPresenter;
        }

        protected override Size MeasureOverride(Size constraint)
        {
            // Here's the secret to getting the adorner to cover the whole control
            this.contentPresenter.Measure(Control.RenderSize);
            return Control.RenderSize;
        }

        protected override Size ArrangeOverride(Size finalSize)
        {
            this.contentPresenter.Arrange(new Rect(finalSize));
            return finalSize;
        }

        #endregion
    }

}

そして私はそれを使用します:

        <toolkit:AutoCompleteBox Margin="5" Text="" Name="searchCategoriesTextBox">
            <i:Interaction.Triggers>
                <i:EventTrigger EventName="TextChanged">
                    <i:InvokeCommandAction Command="{Binding SearchCommand}"  />
                </i:EventTrigger>
            </i:Interaction.Triggers>
            <local:WatermarkService.Watermark>
                <TextBlock TextAlignment="Left" Text="جستجو" FontFamily="Tahoma" Margin="3, -3, 3, 0" />
            </local:WatermarkService.Watermark>
        </toolkit:AutoCompleteBox>

前もって感謝します :)

4

3 に答える 3

2

さて、ついに私はこれを解決するための別の解決策を見つけました。私はRenderTransofrmを使用して、次のように装飾内の制御をミラーリングしました。

    <local:WatermarkService.Watermark>
        <TextBlock Name="watermarkTextBox" 
                    Text="{x:Static resources:Resources.SearchCodingTreeView}" 
                    RenderTransformOrigin="0.5,0.5" TextAlignment="Right">
        <TextBlock.RenderTransform>
            <ScaleTransform ScaleX="-1" />
        </TextBlock.RenderTransform>
        </TextBlock>
    </local:WatermarkService.Watermark>

RenderTransformOrigin="0.5,0.5"ピボットをコントロールの中央にScaleX="-1"置き、水平に反転させます。

于 2012-04-03T18:53:51.047 に答える
0

adornerの調査を行っているときに、MSDNでAdornerのバグの問題をいくつか見たと思います(これは、自分のニーズに合わなかったため、実際には使用しませんでした)。

装飾者の問題が議論された場所へのリンクを見つけることはできませんが、私はそこにかなり確信しています。

于 2012-03-06T21:13:56.823 に答える