Изменение размера кнопки изображения

#java #android #android-layout #imagebutton

#java #Android #android-макет #imagebutton

Вопрос:

Я настраиваю кнопку изображения в Android Studio. В режиме конструктора все выглядит нормально, но при загрузке приложения кнопка изображения перемещается в верхний левый угол и уменьшается в размере?

Показано ниже:

Вид дизайна

XML-код — текущий

 

<?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=".ui.PhysicalActivity">

    <ImageButton
        android:id="@ id/btnImageGallery"
        android:layout_width="200dp"
        android:layout_height="300dp"
        android:layout_marginStart="8dp"
        android:onClick="onImageGalleryClicked"
        android:src="@drawable/placeholder"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.921"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.74" />
</android.support.constraint.ConstraintLayout>
  

Код физической активности

 package com.example.futura.ui;

import android.content.Intent;
import android.net.Uri;
import android.os.Environment;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;

import com.example.futura.R;

import java.io.File;

public class PhysicalActivity extends AppCompatActivity {

    public static final int IMAGE_GALLERY_REQUEST = 20;

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

    }

    public void onImageGalleryClicked(View v){


        // invoke the image gallery using an implict intent.
        Intent photoPickerIntent = new Intent(Intent.ACTION_PICK);

        File pictureDirectory = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES);
        String pictureDirectoryPath = pictureDirectory.getPath();

        // finally, get ui represenation

        Uri data = Uri.parse(pictureDirectoryPath);

        // set the data and type, get all image types

        photoPickerIntent.setDataAndType(data, "image/*" );

        startActivityForResult(photoPickerIntent, IMAGE_GALLERY_REQUEST);


    }

}
  

Предварительный просмотр

Есть ли у кого-нибудь какие-либо советы по исправлению этого?

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

1. кроме того, используя marginTop, вы можете использовать вертикальное смещение. Кроме того, вы не добавили никакого src к своей кнопке изображения

2. попробуйте удалить поле или вы можете установить поле 0

3. при использовании ограничений не указывайте жестко заданные высоту и ширину для imageButton . Пусть он распространяется в соответствии с его ограничениями.

Ответ №1:

Попробуйте добавить layout_constraintHorizontal_bias и layout_constraintStart_toStartOf

 <?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">

    <ImageButton
        android:id="@ id/btnImageGallery"
        android:layout_width="200dp"
        android:layout_height="300dp"
        android:layout_marginStart="8dp"
        android:onClick="onImageGalleryClicked"
        android:src="@drawable/placeholder"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.921"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.74" />
</android.support.constraint.ConstraintLayout>
  

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

1. Спасибо, что добавили это. К сожалению, все еще получаю тот же результат, что и в моем первоначальном предварительном просмотре.

2. как вы раздуваете activity_physical.xml ? Пожалуйста, покажите нам свой java-код для этой части.

3. Что вы имеете в виду? Я использую намерение для активации activity_physical. Хотели бы вы увидеть этот код?

4. Покажите нам свой PhysicalActivity.class . Я протестировал свой код, и он работает нормально

5. Вау, хаха, извините. Спасибо за ваше время и помощь, я ценю это! Я собираюсь притвориться, что этого не произошло … 😉

Ответ №2:

Удалите поля (начало, верх, низ, конец) и отрегулируйте layout_constraintHorizontal_bias , layout_constraintVertical_bias чтобы достичь желаемого результата.

 <android.support.v7.widget.AppCompatImageButton
    android:id="@ id/startSyncButton"
    android:layout_width="200dp"
    android:layout_height="300dp"
    app:layout_constraintHorizontal_bias="0.9"
    app:layout_constraintVertical_bias="0.7"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toTopOf="parent" />
  

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

1. Спасибо вам за это. Я скопировал ваш код и сопоставил его с моим идентификатором приложения. Хотя, я все еще, кажется, получаю тот же результат, что и на моем изображении предварительного просмотра.

2. Игнорировать предыдущий комментарий — я удалил поля и скорректировал эти значения. К сожалению, все еще получаю тот же результат

3. Как насчет activity_physical, activity_physical1, activity_physical2, activity_physical3, …..?

4. Сколько у вас макетов с таким типом именования? и какой макет вы редактируете?

5. Спасибо за вашу помощь. Теперь отсортировано, вы были абсолютно правы. Используя неправильный макет, как идиот 🙂