import
android.content.Context
import
android.os.Bundle
import
android.widget.Toast
import
androidx.activity.ComponentActivity
import
androidx.activity.compose.setContent
import
androidx.compose.foundation.ExperimentalFoundationApi
import
androidx.compose.foundation.Image
import
androidx.compose.foundation.layout.*
import
androidx.compose.foundation.lazy.*
import
androidx.compose.material.*
import
androidx.compose.runtime.*
import
androidx.compose.ui.Alignment
import
androidx.compose.ui.Modifier
import
androidx.compose.ui.graphics.Color
import
androidx.compose.ui.platform.LocalContext
import
androidx.compose.ui.res.painterResource
import
androidx.compose.ui.text.style.TextAlign
import
androidx.compose.ui.unit.*
import
coil.compose.rememberAsyncImagePainter
import
com.example.newcanaryproject.ui.theme.*
import
java.util.*
class
MainActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super
.onCreate(savedInstanceState)
setContent {
NewCanaryProjectTheme {
Surface(
modifier = Modifier.fillMaxSize(),
color = MaterialTheme.colors.background
) {
Scaffold(
topBar = {
TopAppBar(backgroundColor = greenColor,
title = {
Text(
text =
"Horizontal List View Example"
,
modifier = Modifier.fillMaxWidth(),
textAlign = TextAlign.Center,
color = Color.White
)
}
)
}
) {
customListView(LocalContext.current)
}
}
}
}
}
}
@OptIn
(ExperimentalMaterialApi::
class
)
@Composable
fun customListView(context: Context) {
lateinit var courseList: List<ListModel>
courseList = ArrayList<ListModel>()
courseList = courseList + ListModel(
"Android"
, R.drawable.android)
courseList = courseList + ListModel(
"JavaScript"
, R.drawable.js)
courseList = courseList + ListModel(
"Python"
, R.drawable.python)
courseList = courseList + ListModel(
"C++"
, R.drawable.c)
courseList = courseList + ListModel(
"C#"
, R.drawable.csharp)
courseList = courseList + ListModel(
"Java"
, R.drawable.java)
courseList = courseList + ListModel(
"Node Js"
, R.drawable.nodejs)
LazyRow {
itemsIndexed(courseList) { index, item ->
Card(
onClick = {
Toast.makeText(
context,
courseList[index].languageName +
" selected.."
,
Toast.LENGTH_SHORT
).show()
},
modifier = Modifier
.padding(
8
.dp)
.width(
120
.dp),
elevation =
6
.dp
)
{
Column(
modifier = Modifier
.padding(
8
.dp)
.fillMaxWidth(),
horizontalAlignment = Alignment.CenterHorizontally
) {
Spacer(modifier = Modifier.height(
5
.dp))
Image(
painter = painterResource(id = courseList[index].languageImg),
contentDescription =
"img"
,
modifier = Modifier
.height(
60
.dp)
.width(
60
.dp)
.padding(
5
.dp),
alignment = Alignment.Center
)
Spacer(modifier = Modifier.height(
5
.dp))
Text(
text = courseList[index].languageName,
modifier = Modifier.padding(
4
.dp),
color = Color.Black, textAlign = TextAlign.Center
)
}
}
}
}
}