1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
package com.example.myapplication import android.os.Bundle import androidx.activity.ComponentActivity import androidx.activity.compose.setContent import androidx.compose.foundation.layout.* import androidx.compose.material3.MaterialTheme import androidx.compose.material3.Surface import androidx.compose.material3.Text import androidx.compose.runtime.Composable import androidx.compose.ui.Modifier import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp import com.example.myapplication.ui.theme.MyApplicationTheme class MainActivity : ComponentActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContent { MyApplicationTheme { // A surface container using the 'background' color from the theme Surface( modifier = Modifier.fillMaxSize(), color = MaterialTheme.colorScheme.background ) { MainContent() } } } } } @Composable fun MainContent() { // Usar Column como LinearLayout vertical Column( modifier = Modifier .fillMaxSize() .padding(16.dp), verticalArrangement = Arrangement.Center, horizontalAlignment = Alignment.CenterHorizontally ) { Greeting("Android") Spacer(modifier = Modifier.height(16.dp)) Greeting("Compose") } } @Composable fun Greeting(name: String, modifier: Modifier = Modifier) { Text( text = "Hello $name!", modifier = modifier ) } @Preview(showBackground = true) @Composable fun GreetingPreview() { MyApplicationTheme { MainContent() } } |
En este código:
MainContent
: Se ha creado una nueva funciónMainContent
que organiza los elementos en unaColumn
. Esta columna actúa como unLinearLayout
vertical, centrando sus elementos vertical y horizontalmente, y añadiendo un espacio (Spacer
) entre los dosGreeting
.Greeting
: La funciónGreeting
sigue igual, simplemente se utiliza dentro deMainContent
para mostrar diferentes mensajes.GreetingPreview
: El preview ahora muestraMainContent
en lugar de un soloGreeting
, lo que permite ver cómo se verá la interfaz completa.onCreate
: En el métodoonCreate
deMainActivity
, se llama aMainContent
dentro deSurface
para aplicar el tema y el color de fondo.