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

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

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

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

Xamarin

Xamarin(ザマリン)は、iPhoneなどのiOSやAndroidで動作し、C# 言語を用いてアプリを開発できるクロスプラットフォーム開発環境です。Xamarin Studioと C# 言語を用いて、 iOS と Android の両方の開発を行うことができます。

Q&A

解決済

1回答

827閲覧

Xamarin.Forms StackLayout内にAbsoluteLayoutを入れた際にうまく表示がされない場合がある

退会済みユーザー

退会済みユーザー

総合スコア0

XAML

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

Xamarin

Xamarin(ザマリン)は、iPhoneなどのiOSやAndroidで動作し、C# 言語を用いてアプリを開発できるクロスプラットフォーム開発環境です。Xamarin Studioと C# 言語を用いて、 iOS と Android の両方の開発を行うことができます。

0グッド

0クリップ

投稿2018/10/05 11:19

c#

1<StackLayout 2 Spacing="0" 3 VerticalOptions="FillAndExpand"> 4 <StackLayout 5 Spacing="0" 6 VerticalOptions="FillAndExpand" 7 Orientation="Horizontal"> 8 <StackLayout 9 Spacing="0" 10 VerticalOptions="FillAndExpand" 11 WidthRequest="200"> 12 <AbsoluteLayout 13 HorizontalOptions="FillAndExpand" 14 VerticalOptions="FillAndExpand"> 15 <BoxView 16 AbsoluteLayout.LayoutFlags="All" 17 AbsoluteLayout.LayoutBounds="0,0,1,1" 18 BackgroundColor="Aqua"/> 19 </AbsoluteLayout> 20 </StackLayout> 21 <StackLayout 22 Spacing="0" 23 VerticalOptions="FillAndExpand" 24 WidthRequest="200"> 25 <BoxView 26 HorizontalOptions="FillAndExpand" 27 VerticalOptions="FillAndExpand" 28 BackgroundColor="Red"/> 29 </StackLayout> 30 <StackLayout 31 Spacing="0" 32 VerticalOptions="FillAndExpand" 33 WidthRequest="200"> 34 <BoxView 35 HorizontalOptions="FillAndExpand" 36 VerticalOptions="FillAndExpand" 37 BackgroundColor="Red"/> 38 </StackLayout> 39 </StackLayout> 40 </StackLayout>

スマホ画面の幅より長くなるよう幅200のStackLayoutを横に3つ並べたViewを作成します。
このViewの子のStackLayout内にAbsoluteLayoutをセットし、そのAbsoluteLayoutにLayoutFlags="All"でviewを配置するとAbsoluteLayout内のViewが表示されません。
この現象の理由がわからないので分かる方がいましたら教えていただきたいです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

結果から言うと、BoxViewのサイズがWidth=200, Height=0なので表示されません。

<StackLayout Spacing="0" VerticalOptions="FillAndExpand" WidthRequest="200">

Orientation="Vertical"なStackLayoutにVerticalOptions="FillAndExpand"をセットしても効果はありません。
よって、このStackLayoutのサイズはまずWidth=200, Height=0に決定します。
Spacing="0"であるため、最終的なHeightは 全ての子要素のHeightの合計 となります。

<AbsoluteLayout HorizontalOptions="FillAndExpand" VerticalOptions="FillAndExpand">

StackLayoutの子要素であるAbsoluteLayoutのサイズはWidth=200, Height=0に決定します。
HorizontalOptions="FillAndExpand" => 親と同じWidth(200)
VerticalOptions="FillAndExpand" => 親と同じHeight(0)

<BoxView AbsoluteLayout.LayoutFlags="All" AbsoluteLayout.LayoutBounds="0,0,1,1" BackgroundColor="Aqua"/>

LayoutFlagsとLayoutBoundsの組み合わせにより、BoxViewのサイズはWidth=200, Height=0に決定します。
Width => AbsoluteLayoutのWidth(200) * 1.0(100%)
Height => AbsoluteLayoutのHeight(0) * 1.0(100%)

投稿2018/10/05 13:28

P3PPP

総合スコア359

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

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

退会済みユーザー

退会済みユーザー

2018/10/09 02:00 編集

_
退会済みユーザー

退会済みユーザー

2018/10/09 01:57

丁寧なご説明ありがとうございます。 VerticalOptions="FillAndExpand"だと勝手にHeightの値が画面の高さになると思っていました。 勉強になりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問