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

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

新規登録して質問してみよう
ただいま回答率
85.39%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

XAML

XAML(Extensible Application Markup Language)はWPF、Silverlight、Windows PhoneそしてWindows Store appsでユーザーインターフェースを定義するために使われるXML言語です。

WPF

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

Q&A

解決済

2回答

35889閲覧

WPF GridやStackPanelに自動的なサイズ調整

退会済みユーザー

退会済みユーザー

総合スコア0

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

XAML

XAML(Extensible Application Markup Language)はWPF、Silverlight、Windows PhoneそしてWindows Store appsでユーザーインターフェースを定義するために使われるXML言語です。

WPF

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

0グッド

0クリップ

投稿2019/06/30 23:34

実現したいこと
ウィンドウのサイズによってGridやStackPanelのサイズを調整をする

ネットの記事ではコントロールに応じてウィンドウのサイズを自動調整やテキストボックスをウィンドウサイズに応じて調整とゆうのはあったのですが私の実現したいことはありませんでした。
以下に実現したいことの具体例を示させていただきます。

NameがAのStackPanelは高さを30固定とします。
このNameがAのStackPanelの横幅はWindowのサイズに応じて自動調整されます。
続いてNameがBのStackPanelですが横幅、縦幅共にウィンドウのサイズ一杯にして、そのサイズも自動調整させたいです。
この場合はどうすればいいのでしょうか。

さらにNameがCのGridの横幅は150で固定、高さはStackPanelの一杯でサイズも自動調整。
NameがDのGridの横幅と縦幅はNameがBのStackPanelのサイズ一杯にして、そのサイズも自動調整させたいです。
ただ、これは先にあげたStackPanelの自動調整ができれば、独力でできそうな気もします。

お時間ありましたら回答よろしくおねがいします。

<Window x:Class="SampleProject.AutoWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" Width="500" Height="500"> <StackPanel > <StackPanel Name="A" Height="Auto" Orientation="Horizontal" Margin="0 0 0 10" Height="30"> <Button Width="50" Margin="20,0,0,0" HorizontalAlignment="Left" VerticalAlignment="Center" Background="Transparent" Click="Button_Click" Foreground="DarkGray"> </Button> </StackPanel> <StackPanel Name="B" Orientation="Horizontal"> <Grid Width="150" Name="C"> </Grid> <Grid Name="D"/> </StackPanel> </StackPanel> </Window>

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

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

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

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

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

guest

回答2

0

一番外側の StackPanel を Grid にしてください。そして一行目の RowDefinition の Height を Auto にしてください。

投稿2019/06/30 23:38

Zuishin

総合スコア28662

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

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

0

ベストアンサー

DockPanelを使用するほうが良いのかな?
(StackPanelの縛りがある場合、はずしてしまってますが。。。)

xaml

1<Window (略) > 2 <DockPanel> 3 <StackPanel x:Name="A" DockPanel.Dock="Top" Height="30" Background="Red" /> 4 <Grid x:Name="C" DockPanel.Dock="Left" Width="150" Background="Yellow" /> 5 <Grid x:Name="D" Background="Green" /> 6 </DockPanel> 7</Window>

投稿2019/07/01 06:06

lain

総合スコア161

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.39%

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

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

質問する

関連した質問