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

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

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

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Q&A

解決済

1回答

366閲覧

android 水平リニアレイアウトでtextviewの比率を1:1にしたい

luckyclock

総合スコア73

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

0グッド

0クリップ

投稿2018/02/21 07:24

編集2018/02/22 00:07

リニアレイアウトで2段目の水平リニアレイアウトで下記xmlでTextView2とTextView3を調度1:1の比率で表示したいのですがうまくいみません。
andoridstudio上のデザインの見た目では意図する通りとなるのですが、実機で確認するとTextView3の描画開始位置がTextView2の終りの直後となってしまい左詰したような文字列になってしまいます。
期待する動きはTextView2は画面左から描画、TextView3は画面中央から描画が意図する動きです。

期待する表示

xml

1<?xml version="1.0" encoding="utf-8"?> 2<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 3 android:orientation="vertical" 4 android:descendantFocusability="blocksDescendants" 5 android:layout_width="match_parent" 6 android:layout_height="wrap_content"> 7 8 <LinearLayout 9 android:layout_width="match_parent" 10 android:layout_height="wrap_content" 11 android:orientation="vertical"> 12 13 <TextView 14 android:id="@+id/TextView1" 15 android:layout_width="match_parent" 16 android:layout_height="wrap_content" 17 android:paddingBottom="4dp" 18 android:text="date" 19 android:textColor="#000000" 20 android:textSize="16sp" /> 21 22 <LinearLayout 23 android:layout_width="match_parent" 24 android:layout_height="wrap_content" 25 android:orientation="horizontal"> 26 27 <TextView 28 android:id="@+id/TextView2" 29 android:layout_width="match_parent" 30 android:layout_height="wrap_content" 31 android:layout_weight="1" 32 android:text="num" 33 android:textColor="#0000ff" 34 android:textSize="16sp" /> 35 36 <TextView 37 android:id="@+id/TextView3" 38 android:layout_width="match_parent" 39 android:layout_height="wrap_content" 40 android:layout_weight="1" 41 android:text="weight" 42 android:textColor="#0000ff" 43 android:textSize="16sp" /> 44 45 </LinearLayout> 46 47 </LinearLayout> 48 49</LinearLayout>

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

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

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

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

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

guest

回答1

0

ベストアンサー

期待する動きはTextView2は画面左から描画、TextView3は画面中央から描画が意図する動きです。

描画と書くとよくわからなくなる。
実際の期待する位置を図で書いた方がいいのでは?

こうですか?

イメージ説明

<TextView android:id="@+id/TextView2" android:gravity="center_horizontal" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_weight="1" android:text="num" android:textColor="#0000ff" android:textSize="16sp" /> <TextView android:id="@+id/TextView3" android:gravity="center" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:text="weight" android:textColor="#0000ff" android:textSize="16sp" />

あえて異なる書き方にしました

追記:
期待する画像は、元々のコードで実現できていました
たとえばemulatorとかNexusなどでも

考えられることとしては

それぞれの子ビューが画面上で等しいスペースを占める線形レイアウトを作成するには、各ビューの android:layout_height を "0dp"(垂直レイアウトの場合)、または各ビューの android:layout_width を "0dp"(水平レイアウトの場合)に設定します。 次に、各ビューの android:layout_weight を "1" に設定します。

リンク内容

とあるようにこの場合は

android:layout_width="0dp"

とするのが本来の設定でしょう
0dpにすることでどちらに(水平・垂直)weightがかかっているのか明確になります

実機がコードとしては正確ではないと見ているのかもしれません

投稿2018/02/21 09:30

編集2018/02/22 03:09
aja

総合スコア3733

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

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

luckyclock

2018/02/22 00:09

回答ありがとうございます。 期待する表示を追加しました。 weightの左の縦棒が画面センターです。 ajaさんのイメージでnumとweightを左よせした感じになります。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問