Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(5)

Unified Diff: chrome/android/java_staging/src/org/chromium/chrome/browser/ntp/MostVisitedLayout.java

Issue 1206673003: Merge java_staging/src into java/src. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebase Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/android/java_staging/src/org/chromium/chrome/browser/ntp/MostVisitedLayout.java
diff --git a/chrome/android/java_staging/src/org/chromium/chrome/browser/ntp/MostVisitedLayout.java b/chrome/android/java_staging/src/org/chromium/chrome/browser/ntp/MostVisitedLayout.java
deleted file mode 100644
index bdf95cb957bdc25e10a5634db722d4ff549e01d8..0000000000000000000000000000000000000000
--- a/chrome/android/java_staging/src/org/chromium/chrome/browser/ntp/MostVisitedLayout.java
+++ /dev/null
@@ -1,150 +0,0 @@
-// Copyright 2015 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-package org.chromium.chrome.browser.ntp;
-
-import android.content.Context;
-import android.content.res.Resources;
-import android.graphics.Canvas;
-import android.graphics.drawable.Drawable;
-import android.util.AttributeSet;
-import android.view.View;
-import android.widget.FrameLayout;
-
-import org.chromium.base.ApiCompatibilityUtils;
-import org.chromium.chrome.R;
-
-/**
- * A layout that arranges most visited items in a grid. All items must be the same size.
- */
-public class MostVisitedLayout extends FrameLayout {
-
- private int mHorizontalSpacing;
- private int mVerticalSpacing;
- private int mTwoColumnMinWidth;
- private int mThreeColumnMinWidth;
-
- /**
- * The ideal width of a child. The children may need be stretched or shrunk a bit to fill the
- * available width.
- */
- private int mDefaultChildWidth;
-
- private Drawable mEmptyTileDrawable;
- private int mNumEmptyTiles;
- private int mEmptyTileTop;
- private int mFirstEmptyTileLeft;
-
- /**
- * @param context The view context in which this item will be shown.
- * @param attrs The attributes of the XML tag that is inflating the view.
- */
- public MostVisitedLayout(Context context, AttributeSet attrs) {
- super(context, attrs);
- setWillNotDraw(false);
-
- Resources res = getResources();
- mHorizontalSpacing = res.getDimensionPixelOffset(R.dimen.most_visited_spacing);
- mVerticalSpacing = mHorizontalSpacing;
- mDefaultChildWidth = res.getDimensionPixelSize(R.dimen.most_visited_tile_width);
- mTwoColumnMinWidth = res.getDimensionPixelOffset(R.dimen.most_visited_two_column_min_width);
- mThreeColumnMinWidth = res.getDimensionPixelOffset(
- R.dimen.most_visited_three_column_min_width);
- }
-
- @Override
- protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
- // Determine the number of columns in the grid.
- final int totalWidth = MeasureSpec.getSize(widthMeasureSpec);
- int childWidth = mDefaultChildWidth;
- int childWidthWithSpacing = childWidth + mHorizontalSpacing;
-
- int numColumns;
- if (totalWidth + mHorizontalSpacing >= 3 * childWidthWithSpacing) {
- numColumns = 3;
- } else if (totalWidth < mTwoColumnMinWidth) {
- numColumns = 1;
- } else {
- numColumns = totalWidth < mThreeColumnMinWidth ? 2 : 3;
-
- // Resize the tiles to make them fill the entire available width.
- childWidthWithSpacing = Math.max(mHorizontalSpacing,
- (totalWidth + mHorizontalSpacing) / numColumns);
- childWidth = childWidthWithSpacing - mHorizontalSpacing;
- }
-
- int childCount = getChildCount();
- int childHeight = 0;
- if (childCount > 0) {
- // Measure the children.
- int childWidthSpec = MeasureSpec.makeMeasureSpec(childWidth, MeasureSpec.EXACTLY);
- int childHeightSpec = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED);
- for (int i = 0; i < childCount; i++) {
- getChildAt(i).measure(childWidthSpec, childHeightSpec);
- }
- childHeight = getChildAt(0).getMeasuredHeight();
- }
-
- // Arrange the children in a grid.
- int childStart = 0;
- int childTop = 0;
- int column = 0;
- boolean isRtl = ApiCompatibilityUtils.isLayoutRtl(this);
- for (int i = 0; i < childCount; i++) {
- View child = getChildAt(i);
- MarginLayoutParams layoutParams = (MarginLayoutParams) child.getLayoutParams();
- layoutParams.setMargins(isRtl ? 0 : childStart, childTop,
- isRtl ? childStart : 0, 0);
- child.setLayoutParams(layoutParams);
- column++;
- if (column == numColumns) {
- column = 0;
- childStart = 0;
- childTop += childHeight + mVerticalSpacing;
- } else {
- childStart += childWidthWithSpacing;
- }
- }
-
- // Fill the rest of the current row with empty tiles.
- if (column != 0) {
- mNumEmptyTiles = numColumns - column;
- mEmptyTileTop = childTop + getPaddingTop();
- mFirstEmptyTileLeft = isRtl ? 0 : childStart;
- } else {
- mNumEmptyTiles = 0;
- }
-
- int numRows = (childCount + mNumEmptyTiles) / numColumns;
- int totalHeight = getPaddingTop() + getPaddingBottom() + numRows * childHeight
- + (numRows - 1) * mVerticalSpacing;
-
- int gridWidth = numColumns * childWidthWithSpacing - mHorizontalSpacing;
- setMeasuredDimension(gridWidth, resolveSize(totalHeight, heightMeasureSpec));
- }
-
- @Override
- protected void onDraw(Canvas canvas) {
- super.onDraw(canvas);
- if (mNumEmptyTiles == 0 || getChildCount() == 0) return;
-
- // Draw empty tiles.
- if (mEmptyTileDrawable == null) {
- mEmptyTileDrawable = ApiCompatibilityUtils.getDrawable(
- getResources(), R.drawable.most_visited_item_empty);
- }
- int tileLeft = mFirstEmptyTileLeft;
- int tileWidth = getChildAt(0).getMeasuredWidth();
- int tileHeight = getChildAt(0).getMeasuredHeight();
- for (int i = 0; i < mNumEmptyTiles; i++) {
- mEmptyTileDrawable.setBounds(
- tileLeft,
- mEmptyTileTop,
- tileLeft + tileWidth,
- mEmptyTileTop + tileHeight);
- mEmptyTileDrawable.draw(canvas);
- tileLeft += tileWidth + mHorizontalSpacing;
- }
- }
-}

Powered by Google App Engine
This is Rietveld 408576698