卡片

Card 可組合函式可做為 UI 的 Material Design 容器。資訊卡通常會呈現單一連貫的內容。以下列舉幾個可能用到資訊卡的情況:

  • 購物應用程式中的產品。
  • 新聞應用程式中的新聞報導。
  • 通訊應用程式中的訊息。

Card 著重於呈現單一內容,這點與其他容器不同。舉例來說,Scaffold 可為整個畫面提供一般結構。卡片通常是較大的版面配置中的較小 UI 元素,而 ColumnRow 等版面配置元件則提供較簡單且更通用的 API。

內含文字和圖示的升起式資訊卡。
圖 1. 資訊卡填入文字和圖示的範例。

基本導入

Card 的運作方式與 Compose 中的其他容器類似。您可以透過呼叫其中的其他可組合項來宣告其內容。例如,請看以下簡單範例,瞭解 Card 如何包含對 Text 的呼叫:

@Composable
fun CardMinimalExample() {
    Card() {
        Text(text = "Hello, world!")
    }
}

進階導入

如要查看 Card 的 API 定義,請參閱參考資料。並定義多個參數,可讓您自訂元件的外觀和行為。

以下列舉幾個需要注意的重要參數:

  • elevation:為元件新增陰影,讓元件看起來會高於背景。
  • colors:使用 CardColors 類型設定容器和所有子項的預設顏色。
  • enabled:如果您為此參數傳遞 false,資訊卡就會顯示為停用狀態,且不會回應使用者輸入內容。
  • onClick:通常 Card 不會接受點擊事件。因此,您要注意的主要超載是定義 onClick 參數的超載。如果想讓 Card 實作回應使用者按下的按鈕,應使用這個超載。

以下示範如何使用這些參數和其他常見參數 (例如 shapemodifier)。

實心資訊卡

以下範例說明如何實作已填寫的資訊卡。

關鍵在於使用 colors 屬性來變更填充顏色。

@Composable
fun FilledCardExample() {
    Card(
        colors = CardDefaults.cardColors(
            containerColor = MaterialTheme.colorScheme.surfaceVariant,
        ),
        modifier = Modifier
            .size(width = 240.dp, height = 100.dp)
    ) {
        Text(
            text = "Filled",
            modifier = Modifier
                .padding(16.dp),
            textAlign = TextAlign.Center,
        )
    }
}

實作內容如下所示:

資訊卡會填入 Material Design 主題中的表面變化版本顏色。
圖 2. 填入資訊卡的範例。

升高資訊卡

以下程式碼片段說明如何實作升級卡片。使用專屬的 ElevatedCard 可組合函式。

您可以使用 elevation 屬性控制高度和產生的陰影。

@Composable
fun ElevatedCardExample() {
    ElevatedCard(
        elevation = CardDefaults.cardElevation(
            defaultElevation = 6.dp
        ),
        modifier = Modifier
            .size(width = 240.dp, height = 100.dp)
    ) {
        Text(
            text = "Elevated",
            modifier = Modifier
                .padding(16.dp),
            textAlign = TextAlign.Center,
        )
    }
}

此實作方式如下所示:

資訊卡會在應用程式背景上方顯示,並加上陰影。
圖 3. 升高的資訊卡範例。

含外框的資訊卡

以下是外框卡片的範例。使用專屬的 OutlinedCard 可組合函式。

@Composable
fun OutlinedCardExample() {
    OutlinedCard(
        colors = CardDefaults.cardColors(
            containerColor = MaterialTheme.colorScheme.surface,
        ),
        border = BorderStroke(1.dp, Color.Black),
        modifier = Modifier
            .size(width = 240.dp, height = 100.dp)
    ) {
        Text(
            text = "Outlined",
            modifier = Modifier
                .padding(16.dp),
            textAlign = TextAlign.Center,
        )
    }
}

此實作方式如下所示:

卡片具有黑色細邊框。
圖 4. 邊框資訊卡範例。

限制

資訊卡不支援固有的捲動或關閉動作,但可以整合至提供這些功能的可組合項。舉例來說,如要在資訊卡上實作滑動關閉功能,請將資訊卡與 SwipeToDismiss 可組合項整合。如要整合捲動功能,請使用捲動修飾符,例如 verticalScroll。詳情請參閱捲軸說明文件

其他資源