summaryrefslogtreecommitdiffstats
path: root/src/com
diff options
context:
space:
mode:
authorDanesh Mondegarian <daneshm90@gmail.com>2013-10-15 23:30:14 -0700
committerDanesh M <daneshm90@gmail.com>2013-10-16 15:45:07 -0700
commitefa4b8d18459243abf379bb0135ee0a89165a50a (patch)
tree5f9e3cfe0805d38e0bc5720043c5696d0fb026ca /src/com
parent8167b3f78952d386a82347a6934a9c4b3991f288 (diff)
downloadandroid_packages_apps_Trebuchet-efa4b8d18459243abf379bb0135ee0a89165a50a.tar.gz
android_packages_apps_Trebuchet-efa4b8d18459243abf379bb0135ee0a89165a50a.tar.bz2
android_packages_apps_Trebuchet-efa4b8d18459243abf379bb0135ee0a89165a50a.zip
Trebuchet : Fix dynamic padding
Improves dynamic padding based on cellcount / screen size. Change-Id: Ib1c9419a39ea2b3a62be9564373a713a411cb1cf
Diffstat (limited to 'src/com')
-rw-r--r--src/com/cyanogenmod/trebuchet/CellLayout.java27
-rw-r--r--src/com/cyanogenmod/trebuchet/Workspace.java11
-rw-r--r--src/com/cyanogenmod/trebuchet/preference/PreferencesProvider.java3
3 files changed, 19 insertions, 22 deletions
diff --git a/src/com/cyanogenmod/trebuchet/CellLayout.java b/src/com/cyanogenmod/trebuchet/CellLayout.java
index eab7d1e02..2118a95f0 100644
--- a/src/com/cyanogenmod/trebuchet/CellLayout.java
+++ b/src/com/cyanogenmod/trebuchet/CellLayout.java
@@ -74,7 +74,6 @@ public class CellLayout extends ViewGroup {
private int mOriginalHeightGap;
private int mWidthGap;
private int mHeightGap;
- private int mMaxGap;
private boolean mScrollingTransformsDirty = false;
private final Rect mRect = new Rect();
@@ -191,7 +190,6 @@ public class CellLayout extends ViewGroup {
mCellHeight = mOriginalCellHeight = a.getDimensionPixelSize(R.styleable.CellLayout_cellHeight, 10);
mWidthGap = mOriginalWidthGap = a.getDimensionPixelSize(R.styleable.CellLayout_widthGap, 0);
mHeightGap = mOriginalHeightGap = a.getDimensionPixelSize(R.styleable.CellLayout_heightGap, 0);
- mMaxGap = a.getDimensionPixelSize(R.styleable.CellLayout_maxGap, 0);
mCountX = LauncherModel.getWorkspaceCellCountX();
mCountY = LauncherModel.getWorkspaceCellCountY();
mOccupied = new boolean[mCountX][mCountY];
@@ -283,11 +281,6 @@ public class CellLayout extends ViewGroup {
mShortcutsAndWidgets = new ShortcutAndWidgetContainer(context);
- if (!LauncherApplication.isScreenLarge()){
- mCellWidth = (mCellWidth * res.getInteger(R.integer.default_cell_count_x)) / mCountX;
- mCellHeight = (mCellHeight * res.getInteger(R.integer.default_cell_count_y)) / mCountY;
- }
-
mShortcutsAndWidgets.setCellDimensions(mCellWidth, mCellHeight, mWidthGap, mHeightGap);
addView(mShortcutsAndWidgets);
}
@@ -999,10 +992,26 @@ public class CellLayout extends ViewGroup {
if (mOriginalWidthGap < 0 || mOriginalHeightGap < 0) {
int hSpace = widthSpecSize - getPaddingLeft() - getPaddingRight();
int vSpace = heightSpecSize - getPaddingTop() - getPaddingBottom();
+
+ if (hSpace - (mCountX * mCellWidth) < 0) {
+ mCellWidth = hSpace / mCountX;
+ }
+ if (vSpace - (mCountY * mCellHeight) < 0) {
+ mCellHeight = vSpace / mCountY;
+ }
+
int hFreeSpace = hSpace - (mCountX * mCellWidth);
int vFreeSpace = vSpace - (mCountY * mCellHeight);
- mWidthGap = Math.min(mMaxGap, numWidthGaps > 0 ? (hFreeSpace / numWidthGaps) : 0);
- mHeightGap = Math.min(mMaxGap,numHeightGaps > 0 ? (vFreeSpace / numHeightGaps) : 0);
+
+ mWidthGap = 0;
+ mHeightGap = 0;
+
+ if (numWidthGaps > 0) {
+ mWidthGap = hFreeSpace / numWidthGaps;
+ }
+ if (numHeightGaps > 0) {
+ mHeightGap = vFreeSpace / numHeightGaps;
+ }
mShortcutsAndWidgets.setCellDimensions(mCellWidth, mCellHeight, mWidthGap, mHeightGap);
} else {
mWidthGap = mOriginalWidthGap;
diff --git a/src/com/cyanogenmod/trebuchet/Workspace.java b/src/com/cyanogenmod/trebuchet/Workspace.java
index 4dd4523ff..5f0cc5aca 100644
--- a/src/com/cyanogenmod/trebuchet/Workspace.java
+++ b/src/com/cyanogenmod/trebuchet/Workspace.java
@@ -305,7 +305,6 @@ public class Workspace extends PagedView
// Preferences
private int mNumberHomescreens;
private int mDefaultHomescreen;
- private boolean mStretchScreens;
private boolean mShowSearchBar;
private boolean mShowHotseat;
private boolean mHideIconLabels;
@@ -393,12 +392,6 @@ public class Workspace extends PagedView
mDefaultHomescreen = mNumberHomescreens / 2;
}
- mStretchScreens = PreferencesProvider.Interface.Homescreen.getStretchScreens();
- // Large screen has calculated dimensions always, unless specified by config_workspaceTabletGrid option
- boolean workspaceTabletGrid = getResources().getBoolean(R.bool.config_workspaceTabletGrid);
- if (LauncherApplication.isScreenLarge() && workspaceTabletGrid == false) {
- mStretchScreens = false;
- }
mShowSearchBar = PreferencesProvider.Interface.Homescreen.getShowSearchBar();
mShowHotseat = PreferencesProvider.Interface.Dock.getShowDock();
mHideIconLabels = PreferencesProvider.Interface.Homescreen.getHideIconLabels();
@@ -531,9 +524,7 @@ public class Workspace extends PagedView
(LayoutInflater) getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
for (int i = 0; i < mNumberHomescreens; i++) {
CellLayout screen = (CellLayout) inflater.inflate(R.layout.workspace_screen, null);
- if (mStretchScreens) {
- screen.setCellGaps(-1, -1);
- }
+ screen.setCellGaps(-1, -1);
addView(screen);
}
diff --git a/src/com/cyanogenmod/trebuchet/preference/PreferencesProvider.java b/src/com/cyanogenmod/trebuchet/preference/PreferencesProvider.java
index cd88bb5fd..0cf38ae63 100644
--- a/src/com/cyanogenmod/trebuchet/preference/PreferencesProvider.java
+++ b/src/com/cyanogenmod/trebuchet/preference/PreferencesProvider.java
@@ -93,9 +93,6 @@ public final class PreferencesProvider {
return def;
}
}
- public static boolean getStretchScreens() {
- return getBoolean("ui_homescreen_stretch_screens", true);
- }
public static boolean getShowSearchBar() {
return getBoolean("ui_homescreen_general_search", true);
}