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 |
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 Box como FrameLayout Box( modifier = Modifier .fillMaxSize() .padding(16.dp) ) { // Puedes colocar varios elementos en la misma posición Greeting("Android", Modifier.align(Alignment.TopStart)) Greeting("Compose", Modifier.align(Alignment.BottomEnd)) } } @Composable fun Greeting(name: String, modifier: Modifier = Modifier) { Text( text = "Hello $name!", modifier = modifier ) } @Preview(showBackground = true) @Composable fun GreetingPreview() { MyApplicationTheme { MainContent() } } |
Explicación del código:
MainContent
:- Se utiliza un
Box
en lugar de unColumn
oRow
.Box
permite apilar los elementos uno sobre otro. - Los elementos dentro de
Box
se posicionan utilizando el modificadorModifier.align()
que toma parámetros comoAlignment.TopStart
,Alignment.Center
,Alignment.BottomEnd
, etc. - En el ejemplo, uno de los
Greeting
está alineado en la parte superior izquierda y el otro en la parte inferior derecha. Puedes ajustar estas posiciones según tus necesidades.
- Se utiliza un
Greeting
:- La función
Greeting
permanece igual y recibe un modificador para posicionarse correctamente enBox
.
- La función
GreetingPreview
:- El preview muestra cómo quedará la interfaz completa utilizando
MainContent
.
- El preview muestra cómo quedará la interfaz completa utilizando
onCreate
:- En el método
onCreate
, se establece el contenido de la actividad llamando aMainContent
dentro deSurface
.
- En el método