/*
* Copyright (c) 2026 Huawei Device Co., Ltd.
* 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.
*/
// [Start GridLayoutAlgorithm]
import {
DynamicLayout, DynamicLayoutAttribute, GridLayoutAlgorithm, LengthMetrics
} from '@kit.ArkUI';
export class GridDataSource implements IDataSource {
private list: string[] = [];
private listeners: DataChangeListener[] = [];
constructor(list: string[]) {
this.list = list;
}
totalCount(): number {
return this.list.length;
}
getData(index: number): string {
return this.list[index];
}
registerDataChangeListener(listener: DataChangeListener): void {
if (this.listeners.indexOf(listener) < 0) {
this.listeners.push(listener);
}
}
unregisterDataChangeListener(listener: DataChangeListener): void {
const pos = this.listeners.indexOf(listener);
if (pos >= 0) {
this.listeners.splice(pos, 1);
}
}
// 通知控制器数据位置变化
notifyDataMove(from: number, to: number): void {
this.listeners.forEach(listener => {
listener.onDataMove(from, to);
})
}
// 交换元素位置
public swapItem(from: number, to: number): void {
let temp: string = this.list[from];
this.list[from] = this.list[to];
this.list[to] = temp;
this.notifyDataMove(from, to);
}
}
@Entry
@ComponentV2
struct GridLayoutExample {
numbers: GridDataSource = new GridDataSource([]);
@Local flag: boolean = false
@Local gridLayoutAlgorithm: GridLayoutAlgorithm = new GridLayoutAlgorithm({
columnsTemplate: '1fr 1fr 1fr',
columnsGap: LengthMetrics.vp(10),
rowsGap: LengthMetrics.vp(10)
})
aboutToAppear() {
let list: string[] = [];
for (let i = 0; i < 4; i++) {
for (let j = 0; j < 3; j++) {
list.push((i * 3 + j).toString());
}
}
this.numbers = new GridDataSource(list);
}
build() {
Column({ space: 10 }) {
DynamicLayout(this.gridLayoutAlgorithm) {
LazyForEach(this.numbers, (day: string) => {
GridItem() {
Text(day)
.fontSize(16)
.backgroundColor(0xF9CF93)
.width('100%')
.height(80)
.textAlign(TextAlign.Center)
}
}, (index: number) => index.toString())
}.width('100%')
Button('change gridLayoutAlgorithm columns').onClick(() => {
this.flag = !this.flag
if (this.flag) {
this.gridLayoutAlgorithm.columnsTemplate = '1fr 1fr'
} else {
this.gridLayoutAlgorithm.columnsTemplate = '1fr 1fr 1fr'
}
})
}
}
}
// [End GridLayoutAlgorithm]