2021-08-02 12:23:44 -07:00
|
|
|
/*
|
|
|
|
|
* Copyright (C) 2021 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 com.android.launcher3.model;
|
|
|
|
|
|
2021-12-01 18:43:10 +00:00
|
|
|
import static com.android.launcher3.InvariantDeviceProfile.DeviceType;
|
2022-12-16 21:22:27 +00:00
|
|
|
import static com.android.launcher3.LauncherPrefs.DB_FILE;
|
|
|
|
|
import static com.android.launcher3.LauncherPrefs.DEVICE_TYPE;
|
|
|
|
|
import static com.android.launcher3.LauncherPrefs.HOTSEAT_COUNT;
|
|
|
|
|
import static com.android.launcher3.LauncherPrefs.WORKSPACE_SIZE;
|
2021-08-02 12:23:44 -07:00
|
|
|
import static com.android.launcher3.logging.StatsLogManager.LauncherEvent.LAUNCHER_GRID_SIZE_2;
|
|
|
|
|
import static com.android.launcher3.logging.StatsLogManager.LauncherEvent.LAUNCHER_GRID_SIZE_3;
|
|
|
|
|
import static com.android.launcher3.logging.StatsLogManager.LauncherEvent.LAUNCHER_GRID_SIZE_4;
|
|
|
|
|
import static com.android.launcher3.logging.StatsLogManager.LauncherEvent.LAUNCHER_GRID_SIZE_5;
|
2022-01-06 14:52:46 +00:00
|
|
|
import static com.android.launcher3.logging.StatsLogManager.LauncherEvent.LAUNCHER_GRID_SIZE_6;
|
2021-08-02 12:23:44 -07:00
|
|
|
|
|
|
|
|
import android.content.Context;
|
|
|
|
|
import android.text.TextUtils;
|
|
|
|
|
|
|
|
|
|
import com.android.launcher3.InvariantDeviceProfile;
|
2022-11-10 23:07:40 +00:00
|
|
|
import com.android.launcher3.LauncherPrefs;
|
2021-08-02 12:23:44 -07:00
|
|
|
import com.android.launcher3.logging.StatsLogManager.LauncherEvent;
|
2023-05-25 19:20:10 -07:00
|
|
|
import com.android.launcher3.util.MainThreadInitializedObject.SandboxContext;
|
2021-08-02 12:23:44 -07:00
|
|
|
|
|
|
|
|
import java.util.Locale;
|
|
|
|
|
import java.util.Objects;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Utility class representing persisted grid properties.
|
|
|
|
|
*/
|
2022-02-10 13:45:02 +00:00
|
|
|
public class DeviceGridState implements Comparable<DeviceGridState> {
|
2021-08-02 12:23:44 -07:00
|
|
|
|
|
|
|
|
public static final String KEY_WORKSPACE_SIZE = "migration_src_workspace_size";
|
|
|
|
|
public static final String KEY_HOTSEAT_COUNT = "migration_src_hotseat_count";
|
|
|
|
|
public static final String KEY_DEVICE_TYPE = "migration_src_device_type";
|
2022-03-08 21:48:34 +00:00
|
|
|
public static final String KEY_DB_FILE = "migration_src_db_file";
|
2021-08-02 12:23:44 -07:00
|
|
|
|
|
|
|
|
private final String mGridSizeString;
|
|
|
|
|
private final int mNumHotseat;
|
2021-09-10 14:55:54 +01:00
|
|
|
private final @DeviceType int mDeviceType;
|
2022-03-08 21:48:34 +00:00
|
|
|
private final String mDbFile;
|
2021-08-02 12:23:44 -07:00
|
|
|
|
2024-03-04 18:42:24 -06:00
|
|
|
public DeviceGridState(int columns, int row, int numHotseat, int deviceType, String dbFile) {
|
|
|
|
|
mGridSizeString = String.format(Locale.ENGLISH, "%d,%d", columns, row);
|
|
|
|
|
mNumHotseat = numHotseat;
|
|
|
|
|
mDeviceType = deviceType;
|
|
|
|
|
mDbFile = dbFile;
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-02 12:23:44 -07:00
|
|
|
public DeviceGridState(InvariantDeviceProfile idp) {
|
|
|
|
|
mGridSizeString = String.format(Locale.ENGLISH, "%d,%d", idp.numColumns, idp.numRows);
|
|
|
|
|
mNumHotseat = idp.numDatabaseHotseatIcons;
|
2021-12-01 18:43:10 +00:00
|
|
|
mDeviceType = idp.deviceType;
|
2022-03-08 21:48:34 +00:00
|
|
|
mDbFile = idp.dbFile;
|
2021-08-02 12:23:44 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public DeviceGridState(Context context) {
|
2022-12-16 21:22:27 +00:00
|
|
|
LauncherPrefs lp = LauncherPrefs.get(context);
|
|
|
|
|
mGridSizeString = lp.get(WORKSPACE_SIZE);
|
|
|
|
|
mNumHotseat = lp.get(HOTSEAT_COUNT);
|
|
|
|
|
mDeviceType = lp.get(DEVICE_TYPE);
|
|
|
|
|
mDbFile = lp.get(DB_FILE);
|
2021-08-02 12:23:44 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns the device type for the grid
|
|
|
|
|
*/
|
2021-09-10 14:55:54 +01:00
|
|
|
public @DeviceType int getDeviceType() {
|
2021-08-02 12:23:44 -07:00
|
|
|
return mDeviceType;
|
|
|
|
|
}
|
|
|
|
|
|
2022-03-08 21:48:34 +00:00
|
|
|
/**
|
|
|
|
|
* Returns the databaseFile for the grid.
|
|
|
|
|
*/
|
|
|
|
|
public String getDbFile() {
|
|
|
|
|
return mDbFile;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns the number of hotseat icons.
|
|
|
|
|
*/
|
|
|
|
|
public int getNumHotseat() {
|
|
|
|
|
return mNumHotseat;
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-02 12:23:44 -07:00
|
|
|
/**
|
|
|
|
|
* Stores the device state to shared preferences
|
|
|
|
|
*/
|
|
|
|
|
public void writeToPrefs(Context context) {
|
2023-05-25 19:20:10 -07:00
|
|
|
if (context instanceof SandboxContext) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
2022-12-16 21:22:27 +00:00
|
|
|
LauncherPrefs.get(context).put(
|
|
|
|
|
WORKSPACE_SIZE.to(mGridSizeString),
|
|
|
|
|
HOTSEAT_COUNT.to(mNumHotseat),
|
|
|
|
|
DEVICE_TYPE.to(mDeviceType),
|
|
|
|
|
DB_FILE.to(mDbFile));
|
2021-08-02 12:23:44 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns the logging event corresponding to the grid state
|
|
|
|
|
*/
|
|
|
|
|
public LauncherEvent getWorkspaceSizeEvent() {
|
|
|
|
|
if (!TextUtils.isEmpty(mGridSizeString)) {
|
2022-02-10 13:45:02 +00:00
|
|
|
switch (getColumns()) {
|
|
|
|
|
case 6:
|
2022-01-06 14:52:46 +00:00
|
|
|
return LAUNCHER_GRID_SIZE_6;
|
2022-02-10 13:45:02 +00:00
|
|
|
case 5:
|
2021-08-02 12:23:44 -07:00
|
|
|
return LAUNCHER_GRID_SIZE_5;
|
2022-02-10 13:45:02 +00:00
|
|
|
case 4:
|
2021-08-02 12:23:44 -07:00
|
|
|
return LAUNCHER_GRID_SIZE_4;
|
2022-02-10 13:45:02 +00:00
|
|
|
case 3:
|
2021-08-02 12:23:44 -07:00
|
|
|
return LAUNCHER_GRID_SIZE_3;
|
2022-02-10 13:45:02 +00:00
|
|
|
case 2:
|
2021-08-02 12:23:44 -07:00
|
|
|
return LAUNCHER_GRID_SIZE_2;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
2021-09-16 00:10:55 +01:00
|
|
|
public String toString() {
|
|
|
|
|
return "DeviceGridState{"
|
|
|
|
|
+ "mGridSizeString='" + mGridSizeString + '\''
|
|
|
|
|
+ ", mNumHotseat=" + mNumHotseat
|
|
|
|
|
+ ", mDeviceType=" + mDeviceType
|
2022-03-08 21:48:34 +00:00
|
|
|
+ ", mDbFile=" + mDbFile
|
2021-09-16 00:10:55 +01:00
|
|
|
+ '}';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns true if the database from another DeviceGridState can be loaded into the current
|
|
|
|
|
* DeviceGridState without migration, or false otherwise.
|
|
|
|
|
*/
|
|
|
|
|
public boolean isCompatible(DeviceGridState other) {
|
2022-06-17 17:56:18 +01:00
|
|
|
if (this == other) {
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
if (other == null) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
return Objects.equals(mDbFile, other.mDbFile);
|
2021-08-02 12:23:44 -07:00
|
|
|
}
|
2022-02-10 13:45:02 +00:00
|
|
|
|
|
|
|
|
public Integer getColumns() {
|
|
|
|
|
return Integer.parseInt(String.valueOf(mGridSizeString.charAt(0)));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public Integer getRows() {
|
|
|
|
|
return Integer.parseInt(String.valueOf(mGridSizeString.charAt(2)));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public int compareTo(DeviceGridState other) {
|
|
|
|
|
Integer size = getColumns() * getRows();
|
|
|
|
|
Integer otherSize = other.getColumns() * other.getRows();
|
|
|
|
|
|
|
|
|
|
return size.compareTo(otherSize);
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-02 12:23:44 -07:00
|
|
|
}
|