Я пытаюсь получить матчи по дате из футбольного API и показать их сгруппированными по лигам.
Итак, я создал изменяемый список в ViewModel, чтобы хранить каждый элемент матча с идентификатором прибора в качестве уникального идентификатора. . Проблема в том, что элементы добавляются в список при каждом вызове из API, не перезаписывая старые, поэтому список продолжает расти при каждом вызове, и с бесконечным повторением показывается только одна лига (которая содержит две игры в этот день). При изменении даты новые данные добавляются в список вместе со старыми. Я хочу получить доступ к результатам, показанным на следующем изображении.
Если кто-то может помочь, спасибо.
@Composable
fun TodayMatchesLazy(
matchesList: List
) {
val viewModel: MainViewModel = hiltViewModel()
matchesList.forEach {
viewModel.mainList
.add(MatchesByLeague(
leagueId = it!!.league!!.id!!,
leagueName = it.league!!.name!!,
leagueLogo = it.league.logo!!,
matchId = it.fixture!!.id!!,
teamHomeName = it.teams!!.home!!.name!!,
teamHomeLogo = it.teams.home!!.logo!!,
teamAwayName = it.teams.away!!.name!!,
teamAwayLogo = it.teams.away.logo!!,
teamHomeR = it.goals!!.home.toString(),
teamAwayR = it.goals.away.toString(),
time = it.fixture.date!!)
)
}
val groupedList = viewModel.mainList.groupBy { it.leagueId }
if (groupedList .isNotEmpty()) {
LazyColumn(
modifier = Modifier
.padding(20.dp)
.fillMaxSize()
) {
groupedList .forEach { (league, items) ->
item {
Row {
TodayMatchesHeader(leagueItem = matchesList, league = league)
}
}
itemsIndexed(items,
itemContent = { index, item ->
TodayMatchesRow(
teamHomeName = item.teamHomeName,
teamHomeLogo = item.teamHomeLogo,
teamHomeR = item.teamHomeR,
teamAwayName = item.teamAwayName,
teamAwayLogo = item.teamAwayLogo,
teamAwayR = item.teamAwayR,
time = item.time
)
}
)
}
}
}
}
//ViewModel
@HiltViewModel
class MainViewModel @Inject constructor(private val liveMatchesRepository: MainRepository): ViewModel() {
private var _mainList = mutableStateListOf()
val mainList: MutableList = _mainList
}
data class MatchesByLeague(
val leagueId: Int, val leagueName: String, val leagueLogo: String,
val matchId: Int, val teamHomeName: String, val teamHomeLogo: String,
val teamAwayName: String, val teamAwayLogo: String,
val teamHomeR: String, val teamAwayR: String, val time: String
)
ОБНОВЛЕНИЕ:
Основываясь на ответе BenjyTec, я внес некоторые обновления в код. Теперь все работает отлично.
@Composable
fun TodayMatchesLazy(
matchesList: List
) {
val viewModel: MainViewModel = hiltViewModel()
viewModel.mainList.value = matchesList
val groupedList = viewModel.mainList.value.groupBy { it!!.league!!.id }
if (groupedList.isNotEmpty()) {
LazyColumn(
modifier = Modifier
.padding(20.dp)
.fillMaxSize()
) {
groupedList.forEach { (league, items) ->
item {
TodayMatchesHeader(leagueItem = items[0]!!, league = league!!)
}
itemsIndexed(items,
itemContent = { index, item ->
TodayMatchesRow(
teamHomeName = item!!.teams!!.home!!.name!!,
teamHomeLogo = item.teams!!.home!!.logo!!,
teamHomeR = item!!.goals!!.home!!.toString(),
teamAwayName = item.teams.away!!.name!!,
teamAwayLogo = item.teams.away.logo!!,
teamAwayR = item.goals!!.away!!.toString(),
time = item.fixture!!.date!!
)
}
)
}
}
}
}
И модель представления на основе ответа BenjyTec.
@HiltViewModel
class MainViewModel @Inject constructor(private val liveMatchesRepository: MainRepository): ViewModel() {
private var _mainList = mutableStateOf(listOf())
var mainList: MutableState = _mainList
}
Подробнее здесь: https://stackoverflow.com/questions/781 ... temindexed
Просмотр игр API, сгруппированных по идентификатору лиги, получила только первую лигу с itemIndexed ⇐ Android
Форум для тех, кто программирует под Android
1710662305
Гость
Я пытаюсь получить матчи по дате из футбольного API и показать их сгруппированными по лигам.
Итак, я создал изменяемый список в ViewModel, чтобы хранить каждый элемент матча с идентификатором прибора в качестве уникального идентификатора. . Проблема в том, что элементы добавляются в список при каждом вызове из API, не перезаписывая старые, поэтому список продолжает расти при каждом вызове, и с бесконечным повторением показывается только одна лига (которая содержит две игры в этот день). При изменении даты новые данные добавляются в список вместе со старыми. Я хочу получить доступ к результатам, показанным на следующем изображении.
Если кто-то может помочь, спасибо.
@Composable
fun TodayMatchesLazy(
matchesList: List
) {
val viewModel: MainViewModel = hiltViewModel()
matchesList.forEach {
viewModel.mainList
.add(MatchesByLeague(
leagueId = it!!.league!!.id!!,
leagueName = it.league!!.name!!,
leagueLogo = it.league.logo!!,
matchId = it.fixture!!.id!!,
teamHomeName = it.teams!!.home!!.name!!,
teamHomeLogo = it.teams.home!!.logo!!,
teamAwayName = it.teams.away!!.name!!,
teamAwayLogo = it.teams.away.logo!!,
teamHomeR = it.goals!!.home.toString(),
teamAwayR = it.goals.away.toString(),
time = it.fixture.date!!)
)
}
val groupedList = viewModel.mainList.groupBy { it.leagueId }
if (groupedList .isNotEmpty()) {
LazyColumn(
modifier = Modifier
.padding(20.dp)
.fillMaxSize()
) {
groupedList .forEach { (league, items) ->
item {
Row {
TodayMatchesHeader(leagueItem = matchesList, league = league)
}
}
itemsIndexed(items,
itemContent = { index, item ->
TodayMatchesRow(
teamHomeName = item.teamHomeName,
teamHomeLogo = item.teamHomeLogo,
teamHomeR = item.teamHomeR,
teamAwayName = item.teamAwayName,
teamAwayLogo = item.teamAwayLogo,
teamAwayR = item.teamAwayR,
time = item.time
)
}
)
}
}
}
}
//ViewModel
@HiltViewModel
class MainViewModel @Inject constructor(private val liveMatchesRepository: MainRepository): ViewModel() {
private var _mainList = mutableStateListOf()
val mainList: MutableList = _mainList
}
data class MatchesByLeague(
val leagueId: Int, val leagueName: String, val leagueLogo: String,
val matchId: Int, val teamHomeName: String, val teamHomeLogo: String,
val teamAwayName: String, val teamAwayLogo: String,
val teamHomeR: String, val teamAwayR: String, val time: String
)
ОБНОВЛЕНИЕ:
Основываясь на ответе BenjyTec, я внес некоторые обновления в код. Теперь все работает отлично.
@Composable
fun TodayMatchesLazy(
matchesList: List
) {
val viewModel: MainViewModel = hiltViewModel()
viewModel.mainList.value = matchesList
val groupedList = viewModel.mainList.value.groupBy { it!!.league!!.id }
if (groupedList.isNotEmpty()) {
LazyColumn(
modifier = Modifier
.padding(20.dp)
.fillMaxSize()
) {
groupedList.forEach { (league, items) ->
item {
TodayMatchesHeader(leagueItem = items[0]!!, league = league!!)
}
itemsIndexed(items,
itemContent = { index, item ->
TodayMatchesRow(
teamHomeName = item!!.teams!!.home!!.name!!,
teamHomeLogo = item.teams!!.home!!.logo!!,
teamHomeR = item!!.goals!!.home!!.toString(),
teamAwayName = item.teams.away!!.name!!,
teamAwayLogo = item.teams.away.logo!!,
teamAwayR = item.goals!!.away!!.toString(),
time = item.fixture!!.date!!
)
}
)
}
}
}
}
И модель представления на основе ответа BenjyTec.
@HiltViewModel
class MainViewModel @Inject constructor(private val liveMatchesRepository: MainRepository): ViewModel() {
private var _mainList = mutableStateOf(listOf())
var mainList: MutableState = _mainList
}
Подробнее здесь: [url]https://stackoverflow.com/questions/78158075/view-api-games-grouped-by-league-id-only-got-first-league-with-itemindexed[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия