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

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

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

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

Xamarin

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

Q&A

解決済

1回答

6872閲覧

RelativeLayoutでChildrenを追加後に位置を変更する方法

randr

総合スコア202

C#

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

Xamarin

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

0グッド

0クリップ

投稿2016/09/29 12:26

編集2016/09/29 12:44

現在の状態

TabbedPageのような画面を作成中です。
以下はサンプルです。

C#

1var rel = new RelativeLayout(); 2 3var grid = new Grid 4{ 5 BackgroundColor = Color.Navy, 6}; 7for(int i = 1; i <= 3; i++) 8{ 9 grid.Children.Add(new Button 10 { 11 Text = $"button{i}", 12 }, 13 i - 1, 0); 14} 15rel.Children.Add(grid, 16 Constraint.Constant(0), 17 Constraint.RelativeToParent(parent => parent.Height - 50), 18 Constraint.RelativeToParent(parent => parent.Width), 19 Constraint.Constant(50) 20); 21 22var stack2 = new StackLayout 23{ 24 BackgroundColor = Color.Gray, 25 Children = 26 { 27 new Button { Text = "ボタン", } 28 } 29}; 30rel.Children.Add(stack2, 31 Constraint.RelativeToParent(parent => parent.X), 32 Constraint.RelativeToParent(parent => parent.Y), 33 Constraint.RelativeToParent(parent => parent.Width), 34 Constraint.RelativeToView(grid, (parent, sibling) => parent.Height - (sibling.Height)) 35); 36 37MainPage = new ContentPage 38{ 39 Content = rel, 40};

画面イメージ縦

やりたいこと、やってみたこと

横向きになったときに、レイアウトを変更したいと考えています。
画面イメージは下のような感じです。(※画面生成時の配置場所を変更しているため、あくまでも結果イメージです)
画面イメージ横

rel.SizeChanged を使用すれば画面の回転は検知できたのですが、
レイアウトを変更しようとしても、該当のメソッドがどれか見つけれませんでした。

画面生成時に行っていることをしてみようと思い、
RelativeLayoutのChildrenを削除し、改めて追加するようにしましたが、
削除でエラーが出てしました。

すでに存在しているオブジェクトの配置を移動させるにはどうしたらよいのでしょうか?

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

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

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

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

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

guest

回答1

0

ベストアンサー

実は RelativeLayout.Children.Add(View, Constraint, Constraint, Constraint, Constraint) でConstraintを再セットすることが可能です。
(Viewを複数回Addしても重複登録されることはありません)

よって、回転のタイミングでConstraintを再セットして RelativeLayout.ForceLayout() コールするとレイアウトを変更できます。

// ルートのRelativeLayoutのサイズ変更タイミングで回転を判断する rel.SizeChanged += (sender, e) => { if(rel.Width > rel.Height) { // 横向きレイアウト rel.Children.Add(grid, Constraint.RelativeToParent(parent => parent.Width - 50), Constraint.Constant(0), Constraint.Constant(50), Constraint.RelativeToParent(parent => parent.Height) ); rel.Children.Add(stack2, Constraint.RelativeToParent(parent => parent.X), Constraint.RelativeToParent(parent => parent.Y), Constraint.RelativeToView(grid, (parent, sibling) => parent.Width - (sibling.Width)), Constraint.RelativeToParent(parent => parent.Height) ); } else { // 縦向きレイアウト rel.Children.Add(grid, Constraint.Constant(0), Constraint.RelativeToParent(parent => parent.Height - 50), Constraint.RelativeToParent(parent => parent.Width), Constraint.Constant(50) ); rel.Children.Add(stack2, Constraint.RelativeToParent(parent => parent.X), Constraint.RelativeToParent(parent => parent.Y), Constraint.RelativeToParent(parent => parent.Width), Constraint.RelativeToView(grid, (parent, sibling) => parent.Height - (sibling.Height)) ); } // レイアウト再計算 rel.ForceLayout(); };

より厳密にデバイスの向きの変更をチェックしたい場合はリンク先のガイドを参考にしてください。

Checking Device Orientation - Xamarin

投稿2016/10/01 01:39

P3PPP

総合スコア359

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

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

randr

2016/10/01 11:38

わかりやすい説明ありがとうございました。 望み通りの動作を実現できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問