FILL_PARENT внутри ViewFlipper внутри диалога без заголовка - PullRequest
0 голосов
/ 07 января 2012

Я пытаюсь создать ViewFlipper, где каждый дочерний вид имеет некоторый минимальный размер (в зависимости от их содержимого), но каждый должен заполнять внешний ViewFlipper. Поэтому я подумал, что если я сделаю размер каждого ребенка FILL_PARENT, он будет делать именно то, что я хотел бы.

Однако, похоже, что происходит, если размер каждого дочернего элемента рассчитывается индивидуально, затем берется максимум, и это размер ViewFlipper, но расположение дочерних элементов не пересчитывается, чтобы соответствовать этому новый размер. Странно то, что это происходит, только если установлено FEATURE_NO_TITLE.

Ниже приведена демонстрация проблемы. Дочерний 0 имеет размер FILL_PARENT x FILL_PARENT, а дочерний 1 - 100x100, поэтому размер ViewFlipper правильно определен как 100x100. Однако, дочерний 0 не изменен, чтобы быть 100x100; на самом деле он имеет размер 0x0 (как вы можете сказать, когда запускаете приложение и видите красный прямоугольник без следов зеленого на нем). Однако, если вы удалите строку

this.requestWindowFeature(Window.FEATURE_NO_TITLE);

тогда все работает как положено ... Что здесь происходит?

код:

package com.example.flipper;

import android.app.Activity;
import android.os.Bundle;
import android.view.*;
import android.widget.*;

public class MainActivity extends Activity
{
    ViewFlipper flipper;

    @Override
    public void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);

        this.requestWindowFeature(Window.FEATURE_NO_TITLE);

        this.flipper = new ViewFlipper(this);
        flipper.setBackgroundColor(0xffff0000);

        {
            LinearLayout ll = new LinearLayout(this);
            ll.setBackgroundColor(0xff00ff00);
            flipper.addView (ll, new ViewGroup.LayoutParams(ViewGroup.LayoutParams.FILL_PARENT, ViewGroup.LayoutParams.FILL_PARENT));
        }

        {
            LinearLayout ll = new LinearLayout(this);
            ll.setBackgroundColor(0xff0000ff);
            flipper.addView (ll, new ViewGroup.LayoutParams(100, 100));
        }

        setContentView(flipper);
    }

    @Override
    public boolean onTouchEvent(MotionEvent e)
    {
        flipper.setDisplayedChild(1);
        return true;
    }
}

файл манифеста:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.example.flipper"
      android:versionCode="1"
      android:versionName="1.0">
    <application android:label="@string/app_name" >
        <activity android:name="MainActivity"
                  android:theme="@android:style/Theme.Dialog"
                  android:label="@string/app_name">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>
</manifest> 

1 Ответ

1 голос
/ 07 января 2012

Кажется, я смог решить это с помощью клуджа: я обернул ViewFlipper в LinearLayout и установил это как вид деятельности:

LinearLayout llOuter = new LinearLayout(this);
llOuter.addView(flipper, new ViewGroup.LayoutParams(ViewGroup.LayoutParams.FILL_PARENT, ViewGroup.LayoutParams.FILL_PARENT));

setContentView(llOuter);
...