亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

WPF:如何使畫布自動調整大小?

WPF:如何使畫布自動調整大?。?/h1>
回首憶惘然 2019-12-02 10:48:26
我希望Canvas自動將其大小調整為其項目的大小,以便ScrollViewer滾動條具有正確的范圍??梢栽赬AML中完成嗎?<ScrollViewer HorizontalScrollBarVisibility="Auto" x:Name="_scrollViewer">    <Grid x:Name ="_canvasGrid" Background="Yellow">        <Canvas x:Name="_canvas" HorizontalAlignment="Left" VerticalAlignment="Top" Background="Green"></Canvas>        <Line IsHitTestVisible="False" .../>    </Grid></ScrollViewer>在上面的代碼中,畫布始終為0,盡管它不會裁剪其子級。
查看完整描述

3 回答

?
慕森王

TA貢獻1777條經驗 獲得超3個贊

否,這是不可能的(請參見下面的MSDN片段)。但是,如果要具有滾動條和自動調整大小,請考慮改用Grid,并使用Margin屬性將項目放置在此Grid上。Grid會告訴ScrollViewer他想要多大,然后您將畫布總是會告訴ScrollViewer他不需要任何大小。::)


網格讓您同時享受兩個世界-只要將所有元素放入單個單元格,您將同時獲得:任意定位和自動調整大小。通常要記住,大多數面板控件(DockPanel,StackPanel等)都可以通過Grid控件實現。


從MSDN:


畫布是唯一沒有固有布局特征的面板元素。畫布的默認“高度”和“寬度”屬性為零,除非它是自動調整其子元素大小的元素的子元素。畫布的子元素永遠不會調整大小,它們只是位于其指定的坐標處。這為不需要或不需要固有大小限制或對齊的情況提供了靈活性。對于您希望子內容自動調整大小和對齊的情況,通常最好使用Grid元素。


希望這可以幫助


查看完整回答
反對 回復 2019-12-02
?
紅顏莎娜

TA貢獻1842條經驗 獲得超13個贊

我只是在這里復制illef的答案,但要回答PilotBob,您只需定義一個畫布對象,就像這樣


public class CanvasAutoSize : Canvas

{

    protected override System.Windows.Size MeasureOverride(System.Windows.Size constraint)

    {

        base.MeasureOverride(constraint);

        double width = base

            .InternalChildren

            .OfType<UIElement>()

            .Max(i => i.DesiredSize.Width + (double)i.GetValue(Canvas.LeftProperty));


        double height = base

            .InternalChildren

            .OfType<UIElement>()

            .Max(i => i.DesiredSize.Height + (double)i.GetValue(Canvas.TopProperty));


        return new Size(width, height);

    }

}

然后在XAML中使用CanvasAutoSize。


            <local:CanvasAutoSize VerticalAlignment="Top" HorizontalAlignment="Left"></local:CanvasAutoSize>

與上面介紹的使用網格的方法相比,我更喜歡這種解決方案,因為它通過附加屬性工作,只需要在元素上設置較少的屬性即可。


查看完整回答
反對 回復 2019-12-02
  • 3 回答
  • 0 關注
  • 1796 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號