gripПрокрутка и сетка


Просматриваемые области (scroll views) и сетки упрощают создание инвентарей, списков, меню и карточных макетов. Это руководство показывает правильные шаблоны для обоих, включая компоновку, идентификаторы и полосы прокрутки.

circle-info

Следуйте основам пользовательского интерфейса: начинайте с прямоугольников экрана, используйте cut для компоновки и всегда применяйте defer для пар push/pop.

Области прокрутки

Используйте области прокрутки для контента, который может превышать доступное пространство. Полоса прокрутки должна находиться за пределами области содержимого scroll view.

draw_scrollable_list :: proc(items: []string) {
    rect := UI.get_safe_screen_rect()->inset(50);

    // Сначала зарезервируйте место для полосы прокрутки
    scroll_bar_area := rect->cut_right(8)->inset(2);

    settings: Scroll_View_Settings;
    settings.vertical = true;
    settings.horizontal = false;
    settings.clip_padding = {10, 10, 10, 10};

    sv := UI.push_scroll_view(rect, "my_scroll_view", settings); {
        defer UI.pop_scroll_view();

        content := sv.content_rect;
        ts := UI.default_text_settings();
        ts.size = 24;

        for i: 0..items.count-1 {
            item_rect := content->cut_top(40);
            UI.text(item_rect, ts, items[i]);
        }
    }

    scroll_bar_rect := sv->compute_scroll_bar_rect(scroll_bar_area);

    UI.quad(scroll_bar_area, core_globals.white_sprite, {0.025, 0.025, 0.025, 1});
    UI.quad(scroll_bar_rect, core_globals.white_sprite, {0.1, 0.1, 0.1, 1});
}

Важно: Если полоса прокрутки находится внутри содержимого scroll view, это нарушит границы и поведение прокрутки. Всегда сначала вырезайте область для полосы прокрутки.

Сеточная компоновка

Используйте Grid_Layout для элементов одинакового размера, таких как слоты инвентаря или сетки иконок. Сетки начинаются в верхнем левом углу, идут вправо, затем переходят на следующую строку.

Если вы предпочитаете плитки фиксированного размера, используйте .ELEMENT_SIZE вместо .ELEMENT_COUNT:

Метод next() обновляет состояние сетки:

Прокручиваемые сетки

Grid_Layout автоматически расширяют scroll view при использовании внутри него. Этот шаблон идеален для больших инвентарей:

Лучшие практики

  • Используйте UI.push_id() для повторяющихся элементов внутри списков или сеток.

  • Вырезайте область для полосы прокрутки до создания scroll view.

  • Начинайте с UI.get_safe_screen_rect() и отводите от него всю компоновку.

  • Минимизируйте взаимодействия, доступные только при наведении (ориентируйтесь в первую очередь на мобильные устройства).

Последнее обновление