skills/makepad-layout/SKILL.md
CRITICAL: Use for Makepad layout system. Triggers on: makepad layout, makepad width, makepad height, makepad flex, makepad padding, makepad margin, makepad flow, makepad align, Fit, Fill, Size, Walk, "how to center in makepad", makepad 布局, makepad 宽度, makepad 对齐, makepad 居中
npx skillsauth add ZhangHanDong/makepad-skills makepad-layoutInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Version: makepad-widgets (dev branch) | Last Updated: 2026-01-19
Check for updates: https://crates.io/crates/makepad-widgets
You are an expert at Makepad layout system. Help users by:
Refer to the local files for detailed documentation:
./references/layout-system.md - Complete layout reference./references/core-types.md - Walk, Align, Margin, Padding typesBefore answering questions, Claude MUST:
/sync-crate-skills makepad --force 更新文档"<View> {
width: Fill
height: Fill
flow: Down
padding: 16.0
spacing: 8.0
<Label> { text: "Item 1" }
<Label> { text: "Item 2" }
}
<View> {
width: Fill
height: Fill
align: { x: 0.5, y: 0.5 }
<Label> { text: "Centered" }
}
<View> {
width: Fill
height: Fit
flow: Right
spacing: 10.0
align: { y: 0.5 } // Vertically center items
<Button> { text: "Left" }
<View> { width: Fill } // Spacer
<Button> { text: "Right" }
}
<View> {
width: Fill
height: Fill
flow: Down
// Fixed header
<View> {
width: Fill
height: 60.0
}
// Flexible content
<View> {
width: Fill
height: Fill // Takes remaining space
}
}
| Property | Type | Description |
|----------|------|-------------|
| width | Size | Width of element |
| height | Size | Height of element |
| padding | Padding | Inner spacing |
| margin | Margin | Outer spacing |
| flow | Flow | Child layout direction |
| spacing | f64 | Gap between children |
| align | Align | Child alignment |
| clip_x | bool | Clip horizontal overflow |
| clip_y | bool | Clip vertical overflow |
| Value | Description |
|-------|-------------|
| Fit | Size to fit content |
| Fill | Fill available space |
| 100.0 | Fixed size in pixels |
| Fixed(100.0) | Explicit fixed size |
| Value | Description |
|-------|-------------|
| Down | Top to bottom (column) |
| Right | Left to right (row) |
| Overlay | Stack on top |
| Value | Position |
|-------|----------|
| { x: 0.0, y: 0.0 } | Top-left |
| { x: 0.5, y: 0.0 } | Top-center |
| { x: 1.0, y: 0.0 } | Top-right |
| { x: 0.0, y: 0.5 } | Middle-left |
| { x: 0.5, y: 0.5 } | Center |
| { x: 1.0, y: 0.5 } | Middle-right |
| { x: 0.0, y: 1.0 } | Bottom-left |
| { x: 0.5, y: 1.0 } | Bottom-center |
| { x: 1.0, y: 1.0 } | Bottom-right |
+---------------------------+
| margin |
| +---------------------+ |
| | padding | |
| | +---------------+ | |
| | | content | | |
| | +---------------+ | |
| +---------------------+ |
+---------------------------+
Fill for flexible containers, Fit for content-sized elementsflow: Down for vertical, flow: Right for horizontal<View> { width: Fill } as spacer in row layoutsalign to position children within containerFill takes all available space, Fit shrinks to contentdata-ai
CRITICAL: Use for Robius widget patterns. Triggers on: apply_over, TextOrImage, modal, 可复用, 模态, collapsible, drag drop, reusable widget, widget design, pageflip, 组件设计, 组件模式
data-ai
CRITICAL: Use for Robius state management patterns. Triggers on: AppState, persistence, theme switch, 状态管理, Scope::with_data, save state, load state, serde, 状态持久化, 主题切换
tools
CRITICAL: Use for Matrix SDK integration with Makepad. Triggers on: Matrix SDK, sliding sync, MatrixRequest, timeline, matrix-sdk, matrix client, robrix, matrix room, Matrix 集成, 聊天客户端
tools
CRITICAL: Use for Robius event and action patterns. Triggers on: custom action, MatchEvent, post_action, cx.widget_action, handle_actions, DefaultNone, widget action, event handling, 事件处理, 自定义动作