JetPack Compose NavigationBaritem значокAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 JetPack Compose NavigationBaritem значок

Сообщение Anonymous »

Я использую NavigationBar в JetPack Compose и определение значков для каждого элемента, где выбранный элемент должен отображать заполненный значок, а невыбранные должны отображать значок по умолчанию. Тем не менее, выбранная значка всегда применяется, даже если элемент не выбран. < /P>
Вот моя реализация: < /p>
@Composable
fun MyNavBar() {
var selectedItemIndex by rememberSaveable { mutableIntStateOf(0) }
val itemsBarList = listOf(
BottomNavigationItem(
selectedIcon = Icons.Filled.Group,
unselectedIcon = Icons.Default.Group,
),
BottomNavigationItem(
selectedIcon = Icons.Filled.Person,
unselectedIcon = Icons.Default.Person,
),
BottomNavigationItem(
selectedIcon = Icons.Filled.Settings,
unselectedIcon = Icons.Default.Settings,
),
)

NavigationBar {
itemsBarList.forEachIndexed { index, item ->
Log.i("HomePager", "index: $index , selectedItemIndex: $selectedItemIndex")
NavigationBarItem(
selected = index == selectedItemIndex,
onClick = {
selectedItemIndex = index
},
icon = {
Icon(
imageVector = if (index == selectedItemIndex) item.selectedIcon else item.unselectedIcon,
contentDescription = "",
)
},
alwaysShowLabel = true,
)
}
}
}
< /code>
Класс данных BottomNavigationItem определяется как: < /p>
data class BottomNavigationItem(
val selectedIcon: ImageVector,
val unselectedIcon: ImageVector,
)
< /code>
Всякий раз, когда я выбираю новый элемент, правильно обновляется обновления, но переменная индекса всегда, кажется, в конечном итоге в конечном итоге.//here, i selected friends (index 0 on the list)
I index: 0 , selectedItemIndex: 0
I index: 1 , selectedItemIndex: 0
I index: 2 , selectedItemIndex: 0
//changed to profile (index 1 on the list)
I index: 0 , selectedItemIndex: 1
I index: 1 , selectedItemIndex: 1
I index: 2 , selectedItemIndex: 1
< /code>
Несмотря на то, что SelectedIteMindex является правильным, индекс, кажется, всегда заканчивается 2, затрагивая все элементы и их соответствующие значки, и я не имею никакого представления о том, почему это происходит. Любая помощь здесь ценится. Спасибо! < /p>
Редактировать: этот навигационный бассейн используется вместе с пейгером, позволяя пользователям ориентироваться либо, нажав на нижние элементы навигации, либо путем перерыва влево и вправо. Однако, поскольку проблема, по -видимому, связана с тем, как индексируются элементы, и это происходит независимо от того, выбираю ли я элемент через навигацию или проводю в пейджере, я изначально не включил пейджер в фрагмент кода. Поскольку руководящие принципы форума предполагают предоставление минимального воспроизводимого примера, я сосредоточился только на навигационной панели, поскольку только это, по -видимому, достаточно, чтобы воспроизвести проблему.

Подробнее здесь: https://stackoverflow.com/questions/794 ... ritem-icon
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»