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

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

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

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

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

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

введите описание изображения здесь

  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);