Фрагмент не полностью отображается в Activity

#java #android #android-layout #android-fragments

#java #Android #android-макет #android-фрагменты

Вопрос:

В моем приложении у меня есть действие, содержащее простой контейнер (LinearLayout), в котором я хочу отобразить фрагмент. Все это работает, и фрагмент отображается, но он как бы «обрезан» в конце экрана. Это означает, что если во фрагменте экран полностью заполнен кнопками, то в самом запущенном приложении последняя кнопка не отображается или отображается только частично.

Чтобы упростить тестирование, я создал этот новый проект, в котором во фрагменте есть только 3 большие кнопки, которые в функции проектирования в android Studio не расширяют экран, но затем, когда я запускаю его, отключаются.

 <?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".BlankFragment">

    <Button
        android:id="@ id/button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:text="Button"
        android:textSize="100dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <Button
        android:id="@ id/button9"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:text="Button"
        android:textSize="100dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.502"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@ id/button" />

    <Button
        android:id="@ id/button10"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:text="Button"
        android:textSize="70dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.51"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@ id/button9" />

</android.support.constraint.ConstraintLayout>
 
 <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@ id/container"
    android:orientation="vertical"
    tools:context=".MainActivity"/>
 
 package com.example.fragmenttestapp;

import android.content.Context;
import android.net.Uri;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;



public class BlankFragment extends Fragment {

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        return inflater.inflate(R.layout.fragment_blank, container, false);
    }

}
 
 package com.example.fragmenttestapp;

import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentTransaction;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        FragmentManager fragmentManager = getSupportFragmentManager();
        FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();

        BlankFragment fragment = new BlankFragment();
        fragmentTransaction.add(R.id.container, fragment);
        fragmentTransaction.commit();
    }
}

 

Был бы признателен за помощь! 🙂

Комментарии:

1. Для фрагментов линейные макеты не идеальны. Лучше использовать макет фрейма или относительный макет

2. Хорошо, спасибо, но проблема остается также с фреймом или относительным расположением .. есть идеи?

3. Добавьте в mainactivity Linearlayout mlinear = findViewById(. r.id.container);

4. Где именно и что это должно измениться? Также я думаю, вы имеете в виду LinearLayout LinearLayout = findViewById(R.id.container); ? Но я не вижу, что это меняет

5. Удалить пустой фрагмент

Ответ №1:

Я на 99% уверен, что ваши представления не вписываются в ваш экран из-за вашего огромного размера текста в ваших представлениях ( 100dp ), большой размер текста изменит размер вашего представления, и вы используете фиксированный размер для вашего размера текста.
Помните, что фиксированный размер представлений делает ваш макет невосприимчивым

После того, как я удалил ваш размер текста из представлений, все было в порядке, вот пример:

 <?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 
  xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:app="http://schemas.android.com/apk/res-auto"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent">

    <Button
        android:id="@ id/button"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:text="Button"
        app:layout_constraintBottom_toTopOf="@ id/button9"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <Button
        android:id="@ id/button9"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:text="Button"
        app:layout_constraintBottom_toTopOf="@ id/button10"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@ id/button" />

    <Button
        android:id="@ id/button10"
        android:layout_width="w"
        android:layout_height="0dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:layout_marginBottom="8dp"
        android:text="Button"
        app:layout_constraintBottom_toTopOf="@ id/guideline3"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@ id/button9" />

    <androidx.constraintlayout.widget.Guideline
        android:id="@ id/guideline3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        app:layout_constraintGuide_percent="0.5"/>

</androidx.constraintlayout.widget.ConstraintLayout>
 

И если вы хотите использовать большой текст, возможно, используйте автоматическое изменение размера TextViews

Комментарии:

1. Спасибо за ваш ответ! Я только сделал огромный текст, поэтому мне не нужно размещать так много кнопок, но проблема остается прежней, когда я не меняю размер текста, а вместо этого просто добавляю кнопки в xml-дизайн, пока этот экран не будет заполнен. Каким-то образом опубликованный вами код не работает для меня, он жалуется на раздувающийся класс android.constraintlayout. виджет. ConstraintLayout .. вы можете помочь? Спасибо!

2. В общем, что я должен использовать вместо фиксированных размеров? Также для обычных текстовых представлений или изображений, если я хочу, чтобы они отображались в определенном размере?

3. В общем, что я должен использовать вместо фиксированных размеров — я думаю, что ConstraintLayout с рекомендациями — это хорошо. и для вашего первого поста попробуйте скопировать только то, что находится внутри макета ограничений, в ваш макет