繁体   English   中英

在 Android 中单击时放大图像视图

[英]Enlarge Image View When Clicked in Android

我现在使用毕加索有一段时间了,我对它非常满意。 但是我需要放大毕加索从firebase加载的imageview的图像。 下面的代码位于在 MainActivity.java 中调用的 adapter.java

UserRef = FirebaseDatabase.getInstance().getReference().child("user").child(fromUserID);
        UserRef.addValueEventListener(new ValueEventListener() {
            @Override
            public void onDataChange(@NonNull DataSnapshot snapshot) {
                String senderName = snapshot.child("name").getValue().toString();
                String userid = fromUserID;
                if (snapshot.hasChild("avata")){
                 final String receiverImage = snapshot.child("avata").getValue().toString();

                        if (fromUserID.equals(messageSenderId)) {
                            messageViewholder.senderMessageName.setVisibility(View.VISIBLE);
                            messageViewholder.senderImageView.setVisibility(View.VISIBLE);

                            if (fromMessageType.equals("text")) {
                                messageViewholder.senderMessageText.setVisibility(View.VISIBLE);
                                messageViewholder.senderMessageText.setText(messages.getMessage());
                            }else if (fromMessageType.equals("image")) {
                                messageViewholder.senderMessageImage.setVisibility(View.VISIBLE);
                                Picasso.get().load(messages.getMessage()).into(messageViewholder.senderMessageImage);

                            }

这是xml

   <ImageView
        android:id="@+id/receiver_message_image"
        android:layout_width="250dp"
        android:layout_height="wrap_content"
        android:layout_toEndOf="@id/receiver_image"
        android:layout_below="@id/receiver_message_name"
        android:layout_marginStart="5dp"
        android:visibility="gone"
        android:adjustViewBounds="true"
        android:layout_marginEnd="20dp" />

您可以使用ScaleGestureDetector来检测已发生的特定手势事件。 它还可以让您根据手势放大和缩小。 在此示例中,我使用viewBinding将 XML 布局映射到 Java。

XML 布局

    <?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"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:layout_behavior="@string/appbar_scrolling_view_behavior">

    <ImageView
        android:id="@+id/imageView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/symatech_logo"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        />
</androidx.constraintlayout.widget.ConstraintLayout>

Java 代码

   public class EnlargeImageViewWhenClicked extends AppCompatActivity {

    EnlargeImageViewBinding enlargeImageViewBinding;
    ScaleGestureDetector scaleGestureDetector;
    float factor = 1.5f;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        enlargeImageViewBinding = EnlargeImageViewBinding.inflate(getLayoutInflater());
        setContentView(enlargeImageViewBinding.getRoot()); // Setting up the view

        scaleGestureDetector = new ScaleGestureDetector(this, new Listerner()); // Creating the ScaleGestureDetector object.
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        scaleGestureDetector.onTouchEvent(event);
        return super.onTouchEvent(event);
    }

    private class Listerner extends ScaleGestureDetector.SimpleOnScaleGestureListener {
        @Override
        public boolean onScale(ScaleGestureDetector scaleGestureDetector) {
            factor *= scaleGestureDetector.getScaleFactor(); // The scaling factor from the previous scale event being applied to the current event.
            factor = Math.max(0.5f, Math.min(factor, 5.0f));
            enlargeImageViewBinding.imageView.setScaleY(factor);
            enlargeImageViewBinding.imageView.setScaleX(factor);
            return true;
        }
    }
}

在我放大之前在此处输入图像描述

放大后在此处输入图像描述

我当然希望这会有所帮助!

考虑将 ImageView(messageViewholder.senderMessageImage) 置于 ScaleGestureDetector.SimpleOnScaleGestureListener 中的 onScale 函数,就像我给出的示例一样。 像这样的东西(您可能需要编辑代码以适合您的情况。也不要忘记获取其余代码,即初始化ScaleGestureDetector并覆盖onTouchEvent函数)

 private class Listerner extends ScaleGestureDetector.SimpleOnScaleGestureListener {
        @Override
        public boolean onScale(ScaleGestureDetector scaleGestureDetector) {
            factor *= scaleGestureDetector.getScaleFactor(); // The scaling factor from the previous scale event being applied to the current event.
            factor = Math.max(0.5f, Math.min(factor, 5.0f));
            **messageViewholder.senderMessageImage**.setScaleY(factor);
            **messageViewholder.senderMessageImage**.setScaleX(factor);
            return true;
        }
    }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM