Skip Fuse is now free for indie developers!
skip.tools logo

Frame

Skip support for SwiftUI.View.frame on Android. Consult the SkipUI module for a complete list of supported SwiftUI.

The following example screens and source code is from SkipUI’s Showcase sample app FramePlayground.swift

Android screenshot for Frame component (light mode) iPhone screenshot for Frame component (light mode) iPhone screenshot for Frame component (dark mode) Android screenshot for Frame component (dark mode)
import SwiftUI
struct FramePlayground: View {
 var body: some View {
 ScrollView {
 VStack(spacing: 16.0) {
 VStack {
 Text("width: 100")
 HStack {
 Text("A")
 Color.red
 .frame(width: 100.0)
 Text("B")
 }
 }
 .frame(height: 50.0)
 VStack {
 Text("height: 50")
 HStack {
 Text("A")
 Color.red
 .frame(height: 50.0)
 Text("B")
 }
 }
 VStack {
 Text("width: 100, height: 50")
 HStack {
 Text("A")
 Color.red
 .frame(width: 100.0, height: 50.0)
 Text("B")
 }
 }
 VStack {
 Text("minWidth: 0, maxWidth: .infinity,\n minHeight: 0, maxHeight: .infinity")
 HStack {
 Text("A")
 Color.red
 .frame(minWidth: 0.0, maxWidth: .infinity, minHeight: 0.0, maxHeight: .infinity)
 Text("B")
 }
 }
 VStack {
 Text("minWidth: 0, maxWidth: .infinity,\n minHeight: 0, maxHeight: .infinity")
 HStack {
 Text("A")
 Color.red
 .frame(minWidth: 0.0, maxWidth: .infinity, minHeight: 0.0, maxHeight: .infinity)
 Color.blue
 .frame(minWidth: 0.0, maxWidth: .infinity, minHeight: 0.0, maxHeight: .infinity)
 Text("B")
 }
 }
 VStack {
 Text("minWidth: 300, maxWidth: .infinity,\n minHeight: 100, maxHeight: .infinity")
 HStack {
 Text("A")
 Color.red
 .frame(minWidth: 300.0, maxWidth: .infinity, minHeight: 100.0, maxHeight: .infinity)
 Color.blue
 .frame(minWidth: 0.0, maxWidth: .infinity, minHeight: 0.0, maxHeight: .infinity)
 Text("B")
 }
 }
 VStack {
 Text("minWidth: 100,\n minHeight: 0, maxHeight: .infinity")
 HStack {
 Text("A")
 Color.red
 .frame(minWidth: 100.0, minHeight: 0.0, maxHeight: .infinity)
 Color.blue
 .frame(minWidth: 0.0, maxWidth: .infinity, minHeight: 0.0, maxHeight: .infinity)
 Text("B")
 }
 }
 VStack {
 Text("width: 100, height: 100")
 Text("A")
 .frame(width: 100.0, height: 100.0)
 .border(.primary)
 }
 VStack {
 Text("alignment: .bottomTrailing")
 Text("A")
 .frame(width: 100.0, height: 100.0, alignment: .bottomTrailing)
 .border(.primary)
 }
 }
 .padding()
 }
 .toolbar {
 PlaygroundSourceLink(file: "FramePlayground.swift")
 }
 }
}

AltStyle によって変換されたページ (->オリジナル) /