Как я могу убедиться, что мой счетчик (внутри меню) обновляет заголовок моего меню и отображает его полностью? - PullRequest
10 голосов
/ 25 мая 2020

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

Редактировать 2: после повторной настройки эмулятора у меня снова возникают те же проблемы ...

Я попытался реализовать счетчик в моем меню для своего recordExerciseActivity.

recordExerciseActivity

Каждый раз, когда выбирается элемент внутри счетчика, это установлено как новый заголовок меню.

Проблема, с которой я столкнулся, заключается в том, что когда я впервые открываю действие и нажимаю на элемент счетчика, заголовок не обновляется. (Код onItemSelected не запускается)

Однако во второй раз он работает отлично.

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

2

Иногда только первая буква ...

3

Как я могу убедиться, что счетчик правильно обновляет заголовок моего меню каждый раз? (также отображается полное название).

Меню XML

<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">
    <item
        android:id="@+id/spinner"
        android:background="#ffffff"
        app:actionViewClass="android.widget.Spinner"
        app:showAsAction="always"
        android:title="spinner Title" />
</menu>

RecordExerciseActivity


public class RecordExerciseActivity2 extends AppCompatActivity {

    List<String> allChildExerciseNames = new ArrayList<>();
    public static final String PARENT_EXERCISE_ID = "-999";
    public static final String EXTRA_DATE = "com.example.exerciseappv4.EXTRA_DATE";
    public static final String EXTRA_WEEK_DATES = "1";
    public static String EXTRA_JUNCTIONID = "EXERCISE_JUNCTION_ID";
    int parentExerciseID;
    private ChildExerciseViewModel childExerciseViewModel;
    String firstExerciseName;

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

        Intent intent = getIntent();
        if (intent.hasExtra(PARENT_EXERCISE_ID)) {
            parentExerciseID = Integer.parseInt(intent.getStringExtra(PARENT_EXERCISE_ID));
        }

        BottomNavigationView bottomNav = findViewById(R.id.top_navigation);
        bottomNav.setOnNavigationItemSelectedListener(navListener);

        getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container2, new RecordExerciseFragment()).commit();

        getSupportActionBar().setHomeAsUpIndicator(R.drawable.ic_back);
        childExerciseViewModel = ViewModelProviders.of(this).get(ChildExerciseViewModel.class);
        childExerciseViewModel.getChildExerciseNameFromParentID(parentExerciseID).observe(this, this::setChildExerciseName);
        childExerciseViewModel.getAllchildExercisesFromParentID(parentExerciseID).observe(this, this::getAllChildExercisesFromParentID);

    }

    private BottomNavigationView.OnNavigationItemSelectedListener navListener =
            new BottomNavigationView.OnNavigationItemSelectedListener() {
                @Override
                public boolean onNavigationItemSelected(@NonNull MenuItem item) {
                    Fragment selectedFragment = null;

                    switch (item.getItemId()) {
                        case R.id.nav_track:
                            selectedFragment = new RecordExerciseFragment();
                            break;
                        case R.id.nav_history:
                            selectedFragment = new RecordExerciseHistoryFragment();
                            break;
                        case R.id.nav_exercise_list:
                            selectedFragment = new ExerciseGraphFragment();
                            break;
                    }
                    getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container2, selectedFragment).commit();

                    return true;
                }
            };

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        MenuInflater menuInflater = getMenuInflater();
        menuInflater.inflate(R.menu.record_exercise_menu, menu);

        MenuItem item = menu.findItem(R.id.spinner);
        Spinner spinner = (Spinner) item.getActionView();
        ArrayList<String> spinnerStringArray = new ArrayList<>();
        //Add your data to your array
        spinnerStringArray.addAll(allChildExerciseNames);

        ArrayAdapter<String> spinnerAdapter = new ArrayAdapter<String>(this,
                android.R.layout.simple_dropdown_item_1line, allChildExerciseNames);
        spinner.setAdapter(spinnerAdapter);


        spinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
            public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
                Log.i("Spinner Item Selected", "TRUE");
                String selectedExercise = parent.getItemAtPosition(position).toString();
                setTitle(selectedExercise);

            }

            public void onNothingSelected(AdapterView<?> parent) {
            }
        });
        return true;
    }

    private void setChildExerciseName(String childExerciseName) {
        firstExerciseName = childExerciseName;
        setTitle(firstExerciseName);
    }

    private void getAllChildExercisesFromParentID(List<String> allChildExercisesReceived) {
        allChildExerciseNames.addAll(allChildExercisesReceived);
    }
}

Ответы [ 2 ]

1 голос
/ 01 июня 2020

Попробуйте использовать этот пользовательский файл layout для вашего Spinner: simple_spinner_item_custom.xml

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/custom_text_1"
    style="?android:attr/spinnerItemStyle"
    android:singleLine="false"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:ellipsize="none"
    android:textAlignment="inherit" />

Это простая модификация исходного файла simple_spinner_item.xml, чтобы он работал в вашем сценарии с атрибутами редактирования например, android:singleLine="true" и android:ellipsize="marquee", которые не позволяют отображать многострочный текст. Теперь передайте этот макет в качестве аргумента в конструкторе ArrayAdapter как:

ArrayAdapter<String> spinnerAdapter = new ArrayAdapter<>(this,
                R.layout.simple_spinner_item_custom, spinnerStringArray);

Примечание: Нет смысла устанавливать заголовок Activity с помощью метода setTitle(). . Благодаря новой функции LiveLayoutInspector в Android Studio 4.0 я обнаружил, что этот Spinner (как и его родитель, т.е. ActionMenuView) будет растянут, чтобы соответствовать содержимому внутри него, а title из Activity будет зажат. Я безуспешно пытался уменьшить width из Spinner или ActionMenuView. К сожалению, таким образом, я думаю, ваша кнопка навигации назад также будет скрыта. Sandwiched title of the Activity Window Stretched Spinner

Но опять же, если вы используете атрибуты app:showAsAction="ifRoom|collapseActionView" в меню Spinner вы получите более или менее похожий интерфейс. Поиграйте с такими атрибутами, пока они не будут соответствовать вашим потребностям.

Еще одна альтернатива , о которой я могу думать в данный момент, - это inflate обычный menu со стрелкой вниз как icon , затем в onOptionsItemSelected обработайте его, чтобы открыть меню Popup, в котором будет отображаться список элементов, отображаемых в данный момент в вашем Spinner. Затем снова обработайте onClick из Popup, чтобы изменить заголовок Toolbar (потому что title из Activity не поддерживает многострочность и не имеет id, так что его объект не может быть создано).

0 голосов
/ 03 июня 2020

По сути, если вы явно не укажете android studio вызвать onCreateOptionsMenu в onCreate Activity, она не сделает этого до тех пор, пока не начнется взаимодействие с кнопками меню. Итак, что происходит здесь, когда вы выбираете его в первый раз, создается меню, но onClick не регистрируется.

Просто добавление вызова к onCreateOptionsMenu(menu) в конце функции onCreate для Действие, которое должно это исправить.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...