All Downloads are FREE. Search and download functionalities are using the official Maven repository.

commonMain.androidx.compose.foundation.lazy.grid.LazyGridItemInfo.kt Maven / Gradle / Ivy

/*
 * Copyright 2022 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package androidx.compose.foundation.lazy.grid

import androidx.compose.ui.unit.IntOffset
import androidx.compose.ui.unit.IntSize

/**
 * Contains useful information about an individual item in lazy grids like [LazyVerticalGrid].
 *
 * @see LazyGridLayoutInfo
 */
sealed interface LazyGridItemInfo {
    /** The index of the item in the grid. */
    val index: Int

    /** The key of the item which was passed to the item() or items() function. */
    val key: Any

    /**
     * The offset of the item in pixels. It is relative to the top start of the lazy grid container.
     */
    val offset: IntOffset

    /**
     * The row occupied by the top start point of the item. If this is unknown, for example while
     * this item is animating to exit the viewport and is still visible, the value will be
     * [UnknownRow].
     */
    val row: Int

    /**
     * The column occupied by the top start point of the item. If this is unknown, for example while
     * this item is animating to exit the viewport and is still visible, the value will be
     * [UnknownColumn].
     */
    val column: Int

    /**
     * The pixel size of the item. Note that if you emit multiple layouts in the composable slot for
     * the item then this size will be calculated as the max of their sizes.
     */
    val size: IntSize

    /** The content type of the item which was passed to the item() or items() function. */
    val contentType: Any?

    /**
     * The horizontal span of the item if it's in a [LazyVerticalGrid] or the vertical span if the
     * item is in a [LazyHorizontalGrid].
     *
     * Note, [LazyGridLayoutInfo.maxSpan] can be used to get the maximum number of spans in a line,
     * e.g., to check if the item is filling the whole line.
     */
    val span: Int

    companion object {
        /**
         * Possible value for [row], when they are unknown. This can happen when the item is visible
         * while animating to exit the viewport.
         */
        const val UnknownRow = -1
        /**
         * Possible value for [column], when they are unknown. This can happen when the item is
         * visible while animating to exit the viewport.
         */
        const val UnknownColumn = -1
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy