CursosEmpresasBlogLiveConfPrecios

HStack, VStack y el elemento Spacer

Clase 15 de 22 • Curso de SwiftUI desde Cero (2021)

Clase anteriorSiguiente clase

Contenido del curso

Introducción a SwiftUI

  • 1
    ¿Qué es SwiftUI?

    ¿Qué es SwiftUI?

    01:43 min
  • 2
    Instalación de Xcode

    Instalación de Xcode

    02:04 min
  • 3
    Uso y características de Xcode

    Uso y características de Xcode

    12:21 min

Las bases de Swift para SwiftUI

  • 4
    Variables y constantes

    Variables y constantes

    13:17 min
  • 5
    Funciones y argument labels

    Funciones y argument labels

    17:10 min
  • 6
    Structs, propiedades y métodos

    Structs, propiedades y métodos

    09:31 min
  • 7
    Diferencia entre struct y class

    Diferencia entre struct y class

    07:56 min
  • 8
    Computed properties

    Computed properties

    03:07 min
  • 9
    Las bases de SwiftUI e introducción a protocolos

    Las bases de SwiftUI e introducción a protocolos

    05:54 min

Vistas y controles

  • 10
    ¿Qué son las vistas y controles en SwiftUI?

    ¿Qué son las vistas y controles en SwiftUI?

    15:44 min
  • 11
    Botones

    Botones

    13:40 min
  • 12
    Imágenes

    Imágenes

    11:39 min
  • 13
    Campos de texto y el property wrapper @state

    Campos de texto y el property wrapper @state

    13:17 min
  • 14
    Divisores

    Divisores

    08:16 min

Contenedores de interfaz de usuario

  • 15
    HStack, VStack y el elemento Spacer

    HStack, VStack y el elemento Spacer

    Viendo ahora
  • 16
    Resolviendo el reto de contenedores

    Resolviendo el reto de contenedores

    13:20 min
  • 17
    ZStack y el modificador padding

    ZStack y el modificador padding

    18:03 min
  • 18
    Dividir la app en módulos de contenedores

    Dividir la app en módulos de contenedores

    13:10 min

Más vistas y controles

  • 19
    TabView

    TabView

    04:44 min
  • 20
    NavigationView, NavigationLink e introducción a múltiples pantallas

    NavigationView, NavigationLink e introducción a múltiples pantallas

    19:19 min
  • 21
    VideoPlayer

    VideoPlayer

    16:05 min

Las posibilidades de SwiftUI

  • 22
    Las posibilidades de SwiftUI

    Las posibilidades de SwiftUI

    03:44 min
  • Tomar el examen del curso
    • Andrés Antonio Azuara Portillo

      Andrés Antonio Azuara Portillo

      student•
      hace 4 años

      Honestamente pensaba que VStack era algo de View Stack, quedé como payaso cuando me di cuenta que es Vertical Stack jajaja

        Gera Meraki

        Gera Meraki

        student•
        hace 4 años

        Jajajaja no fuiste el único ntp 🤡

      Daniela Lara

      Daniela Lara

      student•
      hace 4 años
      challenge.png
        Alfonso Patron

        Alfonso Patron

        student•
        hace 3 años

        Esa captura la hiciste con VSCODE? O hay alguna extensión para Xcode jajaja

        Luis Carlos Garavito Romero

        Luis Carlos Garavito Romero

        student•
        hace 2 años

        @patronciitoo Puedes usar esta web, soporta varios lenguajes y tiene varios temas, incluido el de la imagen: https://carbon.now.sh/

      José Castillo

      José Castillo

      student•
      hace 4 años

      Me recuerda mucho a Row y Column de Flutter 😄

        Tulio Junior Rangel Nuñez

        Tulio Junior Rangel Nuñez

        student•
        hace 3 años

        Siiii, llevo todo el curso tratando de relacionar todo con Flutter para que se me haga más fácil de entender 😅

      Juan Sebastián Vargas Castañeda

      Juan Sebastián Vargas Castañeda

      student•
      hace 4 años
      • Reto
      // TODO: Reto 1. Hacer el diseño de la imagen llamada "reto". // VStack(alignment: .trailing) { Text("1").border(Color.black) Text("2").border(Color.black) Text("3").border(Color.black) HStack { Text("A").foregroundColor(.black) .frame(width: 100, height: 100, alignment: .center) .background(Color.red) .border(Color.black) HStack(alignment: .top) { Text("B").border(Color.black).background(Color.red) .frame(width: 20, height: 100, alignment: .top) Text("C").border(Color.black).background(Color.red) .frame(width: 20, height: 100, alignment: .top) } }.background(Color.red) }.background(Color.blue) } Algunas partes no son exactas a la solución oficial, pero así me quedó en mi primer intento :)
      Captura de Pantalla 2021-09-20 a la(s) 4.14.27 p. m..png
      Isaac R. Hernández Sánchez

      Isaac R. Hernández Sánchez

      student•
      hace 4 años
      var body: some View{ VStack(alignment: .trailing) { Text("1").border(Color.black) Text("2").border(Color.black) Text("3").border(Color.black) HStack(alignment: .top) { Text("A").frame(width: 150, height: 150, alignment: .center).border(Color.black) Text("B").border(Color.black) Text("C").border(Color.black) } .background(Color.red) } .font(.title) .foregroundColor(.black) .background(Color.blue) }
      Rodrigo Consuelos

      Rodrigo Consuelos

      student•
      hace un año
      struct Reto: View { var body: some View { VStack(alignment:.trailing,spacing: 0){ ForEach(1..<4){index in Text(String(index)).border(.black) }.border(.blue) HStack(alignment:.top){ Text("A").frame(width: /*@START_MENU_TOKEN@*/100/*@END_MENU_TOKEN@*/, height: /*@START_MENU_TOKEN@*/100/*@END_MENU_TOKEN@*/,alignment: .center) .border(.black) Text("B").border(.black) Text("C").border(.black) }.background(.red).border(.black) }.background(.blue).border(.blue) } }
        Rodrigo Consuelos

        Rodrigo Consuelos

        student•
        hace un año
        var body: some View { VStack(alignment:.trailing,spacing: 0){ ForEach(1..<4){index in Text(String(index)).border(.black) } HStack(alignment:.top){ Text("A").frame(width: /*@START_MENU_TOKEN@*/100/*@END_MENU_TOKEN@*/, height: /*@START_MENU_TOKEN@*/100/*@END_MENU_TOKEN@*/,alignment: .center) .border(.black) Text("B").border(.black) Text("C").border(.black) }.background(.red).border(.black) }.background(.blue).border(.blue) }
      Julian Villegas Ospina

      Julian Villegas Ospina

      student•
      hace 2 años
      struct HstackVstackSpacer: View { var body: some View { VStack(alignment: .trailing, spacing: 0.0) { Text("1").border(/*@START_MENU_TOKEN@*/Color.black/*@END_MENU_TOKEN@*/) Text("2").border(/*@START_MENU_TOKEN@*/Color.black/*@END_MENU_TOKEN@*/) Text("3").border(/*@START_MENU_TOKEN@*/Color.black/*@END_MENU_TOKEN@*/) Divider().frame(width: 180, height: 3).background(Color.black) HStack(alignment: .top, spacing: 0.0) { Text("A").frame(width: 100, height: 100) Divider().frame(width: 3, height: 100).background(Color.black) Text("B").border(/*@START_MENU_TOKEN@*/Color.black/*@END_MENU_TOKEN@*/).frame(width: 50) Text("C").border(/*@START_MENU_TOKEN@*/Color.black/*@END_MENU_TOKEN@*/) }.background(Color.red) .padding(3) }.background(Color.blue) .font(/*@START_MENU_TOKEN@*/.title/*@END_MENU_TOKEN@*/) .bold() } } ```struct HstackVstackSpacer: View { var body: some View { VStack(alignment: .trailing, spacing: 0.0) { Text("1").border(/\*@START\_MENU\_TOKEN@\*/Color.black/\*@END\_MENU\_TOKEN@\*/) Text("2").border(/\*@START\_MENU\_TOKEN@\*/Color.black/\*@END\_MENU\_TOKEN@\*/) Text("3").border(/\*@START\_MENU\_TOKEN@\*/Color.black/\*@END\_MENU\_TOKEN@\*/) Divider().frame(width: 180, height: 3).background(Color.black) HStack(alignment: .top, spacing: 0.0) { Text("A").frame(width: 100, height: 100) Divider().frame(width: 3, height: 100).background(Color.black) Text("B").border(/\*@START\_MENU\_TOKEN@\*/Color.black/\*@END\_MENU\_TOKEN@\*/).frame(width: 50) Text("C").border(/\*@START\_MENU\_TOKEN@\*/Color.black/\*@END\_MENU\_TOKEN@\*/) }.background(Color.red) .padding(3) }.background(Color.blue) .font(/\*@START\_MENU\_TOKEN@\*/.title/\*@END\_MENU\_TOKEN@\*/) .bold() } } ![](https://static.platzi.com/media/user_upload/image-08e236c7-a5cd-4003-9722-43a1227eda6e.jpg)
      Ricardo Lira de la Vega

      Ricardo Lira de la Vega

      student•
      hace 2 años

      Para Swift 5.0:

      Ricardo Lira de la Vega

      Ricardo Lira de la Vega

      student•
      hace 2 años

      Para Swift 5.0:

      Christians Bonilla

      Christians Bonilla

      student•
      hace 2 años

      reto

      import SwiftUI struct HstackVstackSpacer: View { var body: some View { VStack(alignment: .trailing,spacing: 0, content: { Text("1").border(.black) Text("2").border(.black) Text("3").border(.black) HStack(alignment: .top, content: { Text("A").frame(width: 100,height: 100,alignment: .center) Divider().frame(width: 2,height: 100).background(.black) Text("B").border(.black) Text("C").border(.black) } ).background(.red) }) .border(.blue).background(.blue) } } #Preview { HstackVstackSpacer() } ```**import** SwiftUI **struct** HstackVstackSpacer: View { **var** body: **some** View { VStack(alignment: .trailing,spacing: 0, content: { Text("1").border(.black) Text("2").border(.black) Text("3").border(.black) HStack(alignment: .top, content: { Text("A").frame(width: 100,height: 100,alignment: .center) Divider().frame(width: 2,height: 100).background(.black) Text("B").border(.black) Text("C").border(.black) } ).background(.red) }) .border(.blue).background(.blue) } } \#Preview { HstackVstackSpacer() }
      Juan Bernardo Henao Orozco

      Juan Bernardo Henao Orozco

      student•
      hace 2 años

      No me aparece el recurso

      Andrea stefanny García mejia

      Andrea stefanny García mejia

      student•
      hace 3 años
      Captura de pantalla 2023-01-29 a la(s) 10.03.57 p.m..png
      Jairo Toro

      Jairo Toro

      student•
      hace 3 años

      Reto:

      struct ChallengeView: View { var body: some View { VStack(alignment: .trailing) { Text("1").border(.black).font(.title2) Text("2").border(.black).font(.title2) Text("3").border(.black).font(.title2) HStack(alignment: .top) { Text("A") .frame(width: 150, height: 150, alignment: .center) .border(.black).font(.title2) Text("B").border(.black) Text("C").border(.black) }.background(Color.red) }.frame(alignment: .trailing).background(Color.blue).border(.blue) } }
      Jesus Moises Bautista Romero

      Jesus Moises Bautista Romero

      student•
      hace 3 años
      codye.png
      Cesar Dominguez

      Cesar Dominguez

      student•
      hace 3 años

      Mi código para el reto

      struct StacksMod: View { var body: some View { VStack(alignment: .trailing) { Text("1").border(.black) Text("2").border(.black) Text("3").border(.black) HStack(alignment: .top) { Text("A").frame(width: 100,height: 100,alignment: .center).border(.black) Text("B").border(.black) Text("C").border(.black) }.background(.red) }.background(.blue) } }
      Diego Fernando Guzmán Rodríguez

      Diego Fernando Guzmán Rodríguez

      student•
      hace 3 años

      Acá mi aporte!

      struct HStacks: View { var body: some View { VStack(alignment: .trailing){ Text("1").border(Color.black) Text("2").border(Color.black) Text("3").border(Color.black) HStack(){ Text("A").frame(width: 200, height: 200, alignment: .center).border(Color.black) HStack(alignment: .top){ Text("B").border(Color.black) Text("C").border(Color.black) }.padding(.bottom, 160) }.background(Color.red).frame(width: 250, height: 200).border(Color.purple) } .background(Color.blue) .frame(width: 250,height: 320) .border(Color.green) .font(.title) } }
      Captura de pantalla 2022-12-15 a la(s) 5.12.39 a.m..png
      Michell Excellent

      Michell Excellent

      student•
      hace 3 años
      Challenge
      struct HVStackChallenge: View { var body: some View { VStack(alignment: .trailing) { VStack { Text("1") .bold() .border(.black) Text("2") .bold() .border(.black) Text("3") .bold() .border(.black) }.frame( width: 200.0, height: 53.0, alignment: .topTrailing ) HStack { Text("A") .padding(.all, 10.0) .frame( width: 200.0, height: .infinity, alignment: .center ) Divider() .frame( width: 1.5, height: 175.0, alignment: .center ) .foregroundColor(.black) .background(.black) HStack(alignment: .top) { Text("B") .bold() .border(.black) Text("C") .bold() .border(.black) }.frame( width: 40.0, height: 175.0, alignment: .topTrailing ) } .border(.blue) .background(.red) } .background(.blue) } }
      Ulises Serrano Pérez

      Ulises Serrano Pérez

      student•
      hace 3 años

      Yo lo resolvi de la siguiente manera.

      Simulator Screen Shot - iPhone 14 Pro - 2022-11-10 at 23.22.41.png

      struct HStackVStackSpacer: View { var body: some View { VStack(alignment:.trailing) { Text("1") .border(.black) Text("2") .border(.black) Text("3") .border(.black) HStack(alignment: .top){ Text("A") .frame(width: 100, height: 100, alignment: .center) .border(.black) HStack { Text("B") .border(.black) Text("C") .border(.black) } } .background(Color.red) } .background(Color.blue) } }
      dennis oswaldo saenz hernandez

      dennis oswaldo saenz hernandez

      student•
      hace 3 años

      var body: some View {

      VStack(alignment: .trailing ) { Text("1").border(/*@START_MENU_TOKEN@*/Color.black/*@END_MENU_TOKEN@*/) Text("2").border(/*@START_MENU_TOKEN@*/Color.black/*@END_MENU_TOKEN@*/) Text("3").border(/*@START_MENU_TOKEN@*/Color.black/*@END_MENU_TOKEN@*/) HStack(alignment: .top ){ Text("A").frame(width: 120, height: 120, alignment: /*@START_MENU_TOKEN@*/.center/*@END_MENU_TOKEN@*/) .border(/*@START_MENU_TOKEN@*/Color.black/*@END_MENU_TOKEN@*/) HStack(alignment: .center ){ Text("B").border(/*@START_MENU_TOKEN@*/Color.black/*@END_MENU_TOKEN@*/) Text("C").border(/*@START_MENU_TOKEN@*/Color.black/*@END_MENU_TOKEN@*/) } }.background(Color.red) }.border(Color.blue).background(Color.blue) }
      Captura de Pantalla 2022-11-07 a la(s) 17.06.19.png
      Alan Maldonado

      Alan Maldonado

      student•
      hace 3 años

      ![](

      Screen Shot 2022-10-05 at 17.11.15.png

    Escuelas

    • Desarrollo Web
      • Fundamentos del Desarrollo Web Profesional
      • Diseño y Desarrollo Frontend
      • Desarrollo Frontend con JavaScript
      • Desarrollo Frontend con Vue.js
      • Desarrollo Frontend con Angular
      • Desarrollo Frontend con React.js
      • Desarrollo Backend con Node.js
      • Desarrollo Backend con Python
      • Desarrollo Backend con Java
      • Desarrollo Backend con PHP
      • Desarrollo Backend con Ruby
      • Bases de Datos para Web
      • Seguridad Web & API
      • Testing Automatizado y QA para Web
      • Arquitecturas Web Modernas y Escalabilidad
      • DevOps y Cloud para Desarrolladores Web
    • English Academy
      • Inglés Básico A1
      • Inglés Básico A2
      • Inglés Intermedio B1
      • Inglés Intermedio Alto B2
      • Inglés Avanzado C1
      • Inglés para Propósitos Específicos
      • Inglés de Negocios
    • Marketing Digital
      • Fundamentos de Marketing Digital
      • Marketing de Contenidos y Redacción Persuasiva
      • SEO y Posicionamiento Web
      • Social Media Marketing y Community Management
      • Publicidad Digital y Paid Media
      • Analítica Digital y Optimización (CRO)
      • Estrategia de Marketing y Growth
      • Marketing de Marca y Comunicación Estratégica
      • Marketing para E-commerce
      • Marketing B2B
      • Inteligencia Artificial Aplicada al Marketing
      • Automatización del Marketing
      • Marca Personal y Marketing Freelance
      • Ventas y Experiencia del Cliente
      • Creación de Contenido para Redes Sociales
    • Inteligencia Artificial y Data Science
      • Fundamentos de Data Science y AI
      • Análisis y Visualización de Datos
      • Machine Learning y Deep Learning
      • Data Engineer
      • Inteligencia Artificial para la Productividad
      • Desarrollo de Aplicaciones con IA
      • AI Software Engineer
    • Ciberseguridad
      • Fundamentos de Ciberseguridad
      • Hacking Ético y Pentesting (Red Team)
      • Análisis de Malware e Ingeniería Forense
      • Seguridad Defensiva y Cumplimiento (Blue Team)
      • Ciberseguridad Estratégica
    • Liderazgo y Habilidades Blandas
      • Fundamentos de Habilidades Profesionales
      • Liderazgo y Gestión de Equipos
      • Comunicación Avanzada y Oratoria
      • Negociación y Resolución de Conflictos
      • Inteligencia Emocional y Autogestión
      • Productividad y Herramientas Digitales
      • Gestión de Proyectos y Metodologías Ágiles
      • Desarrollo de Carrera y Marca Personal
      • Diversidad, Inclusión y Entorno Laboral Saludable
      • Filosofía y Estrategia para Líderes
    • Diseño de Producto y UX
      • Fundamentos de Diseño UX/UI
      • Investigación de Usuarios (UX Research)
      • Arquitectura de Información y Usabilidad
      • Diseño de Interfaces y Prototipado (UI Design)
      • Sistemas de Diseño y DesignOps
      • Redacción UX (UX Writing)
      • Creatividad e Innovación en Diseño
      • Diseño Accesible e Inclusivo
      • Diseño Asistido por Inteligencia Artificial
      • Gestión de Producto y Liderazgo en Diseño
      • Diseño de Interacciones Emergentes (VUI/VR)
      • Desarrollo Web para Diseñadores
      • Diseño y Prototipado No-Code
    • Contenido Audiovisual
      • Fundamentos de Producción Audiovisual
      • Producción de Video para Plataformas Digitales
      • Producción de Audio y Podcast
      • Fotografía y Diseño Gráfico para Contenido Digital
      • Motion Graphics y Animación
      • Contenido Interactivo y Realidad Aumentada
      • Estrategia, Marketing y Monetización de Contenidos
    • Desarrollo Móvil
      • Fundamentos de Desarrollo Móvil
      • Desarrollo Nativo Android con Kotlin
      • Desarrollo Nativo iOS con Swift
      • Desarrollo Multiplataforma con React Native
      • Desarrollo Multiplataforma con Flutter
      • Arquitectura y Patrones de Diseño Móvil
      • Integración de APIs y Persistencia Móvil
      • Testing y Despliegue en Móvil
      • Diseño UX/UI para Móviles
    • Diseño Gráfico y Arte Digital
      • Fundamentos del Diseño Gráfico y Digital
      • Diseño de Identidad Visual y Branding
      • Ilustración Digital y Arte Conceptual
      • Diseño Editorial y de Empaques
      • Motion Graphics y Animación 3D
      • Diseño Gráfico Asistido por Inteligencia Artificial
      • Creatividad e Innovación en Diseño
    • Programación
      • Fundamentos de Programación e Ingeniería de Software
      • Herramientas de IA para el trabajo
      • Matemáticas para Programación
      • Programación con Python
      • Programación con JavaScript
      • Programación con TypeScript
      • Programación Orientada a Objetos con Java
      • Desarrollo con C# y .NET
      • Programación con PHP
      • Programación con Go y Rust
      • Programación Móvil con Swift y Kotlin
      • Programación con C y C++
      • Administración Básica de Servidores Linux
    • Negocios
      • Fundamentos de Negocios y Emprendimiento
      • Estrategia y Crecimiento Empresarial
      • Finanzas Personales y Corporativas
      • Inversión en Mercados Financieros
      • Ventas, CRM y Experiencia del Cliente
      • Operaciones, Logística y E-commerce
      • Gestión de Proyectos y Metodologías Ágiles
      • Aspectos Legales y Cumplimiento
      • Habilidades Directivas y Crecimiento Profesional
      • Diversidad e Inclusión en el Entorno Laboral
      • Herramientas Digitales y Automatización para Negocios
    • Blockchain y Web3
      • Fundamentos de Blockchain y Web3
      • Desarrollo de Smart Contracts y dApps
      • Finanzas Descentralizadas (DeFi)
      • NFTs y Economía de Creadores
      • Seguridad Blockchain
      • Ecosistemas Blockchain Alternativos (No-EVM)
      • Producto, Marketing y Legal en Web3
    • Recursos Humanos
      • Fundamentos y Cultura Organizacional en RRHH
      • Atracción y Selección de Talento
      • Cultura y Employee Experience
      • Gestión y Desarrollo de Talento
      • Desarrollo y Evaluación de Liderazgo
      • Diversidad, Equidad e Inclusión
      • AI y Automatización en Recursos Humanos
      • Tecnología y Automatización en RRHH
    • Finanzas e Inversiones
      • Fundamentos de Finanzas Personales y Corporativas
      • Análisis y Valoración Financiera
      • Inversión y Mercados de Capitales
      • Finanzas Descentralizadas (DeFi) y Criptoactivos
      • Finanzas y Estrategia para Startups
      • Inteligencia Artificial Aplicada a Finanzas
      • Domina Excel
      • Financial Analyst
      • Conseguir trabajo en Finanzas e Inversiones
    • Startups
      • Fundamentos y Validación de Ideas
      • Estrategia de Negocio y Product-Market Fit
      • Desarrollo de Producto y Operaciones Lean
      • Finanzas, Legal y Fundraising
      • Marketing, Ventas y Growth para Startups
      • Cultura, Talento y Liderazgo
      • Finanzas y Operaciones en Ecommerce
      • Startups Web3 y Blockchain
      • Startups con Impacto Social
      • Expansión y Ecosistema Startup
    • Cloud Computing y DevOps
      • Fundamentos de Cloud y DevOps
      • Administración de Servidores Linux
      • Contenerización y Orquestación
      • Infraestructura como Código (IaC) y CI/CD
      • Amazon Web Services
      • Microsoft Azure
      • Serverless y Observabilidad
      • Certificaciones Cloud (Preparación)
      • Plataforma Cloud GCP

    Platzi y comunidad

    • Platzi Business
    • Live Classes
    • Lanzamientos
    • Executive Program
    • Trabaja con nosotros
    • Podcast

    Recursos

    • Manual de Marca

    Soporte

    • Preguntas Frecuentes
    • Contáctanos

    Legal

    • Términos y Condiciones
    • Privacidad
    • Tyc promociones
    Reconocimientos
    Reconocimientos
    Logo reconocimientoTop 40 Mejores EdTech del mundo · 2024
    Logo reconocimientoPrimera Startup Latina admitida en YC · 2014
    Logo reconocimientoPrimera Startup EdTech · 2018
    Logo reconocimientoCEO Ganador Medalla por la Educación T4 & HP · 2024
    Logo reconocimientoCEO Mejor Emprendedor del año · 2024
    De LATAM conpara el mundo
    YoutubeInstagramLinkedInTikTokFacebookX (Twitter)Threads