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

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

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

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

.NET Framework 4.0

Microsoft Windows用のソフトウェア開発環境/実行環境である .NET Frameworkの4番目のメジャーバージョンです。

WPF

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

Q&A

0回答

954閲覧

Viewbox内のItemsControlでHorizontalContentAlignmentが効かない

arw.tyx-out_mz

総合スコア27

C#

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

.NET Framework 4.0

Microsoft Windows用のソフトウェア開発環境/実行環境である .NET Frameworkの4番目のメジャーバージョンです。

WPF

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

0グッド

0クリップ

投稿2019/08/06 15:07

前提・実現したいこと

WPFでGUIアプリを制作しているのですが,Viewbox内に配置したItemsControlで,高さ方向はStretchしてくれますが,幅方向にStretchしてくれません.

該当のソースコード

今回の質問と関連なさそうなSliderのスタイルやConverterの詳細については割愛させていただきます.

Xaml

1 <GroupBox> 2 <GroupBox.Header> 3 <Label Content="グループボックス" FontSize="18" /> 4 </GroupBox.Header> 5 <Viewbox Stretch="Uniform"> 6 <ItemsControl ItemsSource="{Binding HogeCollection}" HorizontalContentAlignment="Stretch" 7 ItemTemplate="{StaticResource HogeItemLayout}"> 8 </ItemsControl> 9 </Viewbox> 10 </GroupBox> 11

Xaml

1 <DataTemplate x:Key="HogeItemLayout"> 2 <Grid> 3 <Grid.RowDefinitions> 4 <RowDefinition/> 5 <RowDefinition/> 6 </Grid.RowDefinitions> 7 <Grid.ColumnDefinitions> 8 <ColumnDefinition Width="*"/> 9 <ColumnDefinition Width="3*"/> 10 <ColumnDefinition Width="2*"/> 11 <ColumnDefinition Width="*"/> 12 </Grid.ColumnDefinitions> 13 14 <Viewbox Grid.Row="0" Grid.Column="0"> 15 <Label Content="{Binding Id}"/> 16 </Viewbox> 17 <Viewbox Grid.Row="0" Grid.Column="1"> 18 <Label HorizontalAlignment="Left" Content="{Binding Name}"/> 19 </Viewbox> 20 <Viewbox Grid.Row="0" Grid.Column="2"> 21 <Label HorizontalAlignment="Right" Content="{Binding CurrentNum, Converter={StaticResource ToStringConverter}}"/> 22 </Viewbox> 23 <Viewbox Grid.Row="0" Grid.Column="3"> 24 <Label Content="mm"/> 25 </Viewbox> 26 <Slider Grid.Row="1" Grid.Column="0" Grid.ColumnSpan="4" 27 Style="{StaticResource CustomSliderStyle}" 28 Foreground="{DynamicResource CynBrush}" 29 Maximum="{Binding Total}" 30 Value="{Binding CurrentVolume}"> 31 </Slider> 32 </Grid> 33 </DataTemplate> 34

試したこと

調べてHorizontalContentAlignmentStretchを適用してみましたが,うまくいきませんでした....

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

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

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

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

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

takabosoft

2019/08/08 05:46

縮小表示された結果、ItemTemplateで表示される要素の左右に隙間ができるので、その隙間がうまるように横に広げたい的な話ですかね?
arw.tyx-out_mz

2019/08/08 13:51

まさにそれです! ただStretchをFillやUniformToFillのような状態にするのではなく,ItemTemplateのGridの幅が広がることで左右の隙間を埋めてほしいのです.
takabosoft

2019/08/09 00:24

そういう機能はViewboxには無いんじゃないですかね。 中で表示される要素の数とかが固定でしたら、固定値でちょろまかすこともできそうですが変動するのであれば自分でViewboxのようなものを作って、子要素のアスペクト比が揃うように幅か高さを拡張してから縮小表示するしかないのかなとは思いました。 詳しい方の回答を待ちましょう。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問