Как предотвратить конфликтную анимацию с поворотом устройства в Android?

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

ObjectAnimator move_next_btn = ObjectAnimator.ofFloat(next_btn, "x", next_btn.getX(),
                        next_btn.getX() + next_btn.getWidth());

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

Я приведу более подробно с изображением:

  1. это мой просмотрщик картинок с двумя боковыми кнопками, когда пользователь не трогает экранные кнопки с анимацией, выходящей за пределы экрана:

  1. второе изображение показывает, что одна из стрелок - скрыть (возможно), я думаю, это потому, что когда анимация хочет работать, я поворачиваю экран, и стрелка остается вне экрана:

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

это происходит только тогда, когда анимация перемещения (int над кодом) и поворот экрана запускаются не всегда.

полный код:

private void init() {
        index = getIntent().getIntExtra("index", 0);
        current_index = getIntent().getIntExtra("current_index", 0);

        final View previous_btn_rl = findViewById(R.id.previous_btn_rl);
        findViewById(R.id.previous_btn_rl).findViewById(R.id.previous_btn)
                .setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                time_to_hide_button = 3;
                try {
                    AssetManager assetManager = getAssets();
                    if (current_index > 0) {
                        current_index--;
                        String path = "img" + "/" + String.valueOf(index + 1) + "/gallery/" + String.valueOf(current_index + 1) + ".jpg";
                        imageView.setImageBitmap(BitmapFactory.decodeStream(assetManager.open(path)));
                    }
                } catch (Exception e) {
                    Log.d(TAG, "onClick: " + e.getMessage());
                }
            }
        });

        final View next_btn_rl = findViewById(R.id.next_btn_rl);
        findViewById(R.id.next_btn_rl).findViewById(R.id.next_btn)
            .setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                time_to_hide_button = 3;

                try {
                    AssetManager assetManager = getAssets();
                    int fileCount = assetManager.list("img" + "/" + String.valueOf(index + 1) + "/gallery").length;
                    if (current_index < (fileCount - 1)) {
                        current_index++;
                        String path = "img" + "/" + String.valueOf(index + 1) + "/gallery/" + String.valueOf(current_index + 1) + ".jpg";
                        imageView.setImageBitmap(BitmapFactory.decodeStream(assetManager.open(path)));
                    }
                } catch (Exception e) {
                    Log.d(TAG, "onClick: " + e.getMessage());
                }

            }
        });

        imageView = (ImageView)findViewById(R.id.image_view);
        imageView.setOnTouchListener(new View.OnTouchListener() {
            @Override
            public boolean onTouch(View view, MotionEvent motionEvent) {

                if (previous_btn_rl.getX() == -previous_btn_rl.getWidth()) {

                    ObjectAnimator move_previous_btn = ObjectAnimator.ofFloat(previous_btn_rl, "x", -previous_btn_rl.getWidth(), 0);
                    ObjectAnimator move_next_btn = ObjectAnimator.ofFloat(next_btn_rl, "x",
                            next_btn_rl.getX(),
                            next_btn_rl.getX() -next_btn_rl.getWidth());

                    AnimatorSet set = new AnimatorSet();
                    set.setDuration(500);
                    set.setInterpolator(new AccelerateInterpolator());
                    set.playTogether(move_previous_btn, move_next_btn);
                    set.start();
                }

                time_to_hide_button = 3;
                return false;
            }
        });

        try {
            AssetManager assetManager = getAssets();
            String path = "img" + "/" + String.valueOf(index + 1) + "/gallery/" + String.valueOf(current_index + 1) + ".jpg";
            imageView.setImageBitmap(BitmapFactory.decodeStream(assetManager.open(path)));
        } catch (Exception e) {
            Log.d(TAG, "init: ");
        }

        handler.post(new Runnable() {
            @Override
            public void run() {

                if (time_to_hide_button <= 0 && previous_btn_rl.getX() == 0) {

                    ObjectAnimator move_previous_btn = ObjectAnimator.ofFloat(previous_btn_rl, "x", 0, -previous_btn_rl.getWidth());
                    ObjectAnimator move_back_btn = ObjectAnimator.ofFloat(next_btn_rl, "x",
                            next_btn_rl.getX(),
                            next_btn_rl.getX() + next_btn_rl.getWidth());


                    AnimatorSet set = new AnimatorSet();
                    set.setDuration(500);
                    set.setInterpolator(new AccelerateInterpolator());
                    set.playTogether(move_previous_btn, move_back_btn);
                    set.start();

                } else {
                    if (time_to_hide_button > 0) {
                        time_to_hide_button--;
                    }
                }

                handler.postDelayed(this, 1000);
            }
        });
    }

Я записал свою проблему: мое проблемное видео на YouTube

Какой лучший способ предотвратить эту проблему?

1 ответ

Для временной блокировки экрана вы можете легко использовать:

//for android tablets **<uses-sdk android:minSdkVersion="12" />**
//works perfectly... **WATCH OUT**: look portrait to reverse-portrait on api level 13 :)

currentActivity.setRequestedOrientation(currentActivity.getResources().getConfiguration().orientation);

//to re-enable sensor, just do:

currentActivity.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_SENSOR);
Другие вопросы по тегам