| Index: chrome/android/java_staging/src/org/chromium/chrome/browser/ntp/NewTabPageLayout.java
|
| diff --git a/chrome/android/java_staging/src/org/chromium/chrome/browser/ntp/NewTabPageLayout.java b/chrome/android/java_staging/src/org/chromium/chrome/browser/ntp/NewTabPageLayout.java
|
| deleted file mode 100644
|
| index da2234d7509b8cdf7b6a09670c3321e4f43edfe6..0000000000000000000000000000000000000000
|
| --- a/chrome/android/java_staging/src/org/chromium/chrome/browser/ntp/NewTabPageLayout.java
|
| +++ /dev/null
|
| @@ -1,148 +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.util.AttributeSet;
|
| -import android.view.View;
|
| -
|
| -import org.chromium.chrome.R;
|
| -import org.chromium.chrome.browser.widget.BoundedLinearLayout;
|
| -
|
| -/**
|
| - * Layout for the new tab page. This positions the page elements in the correct vertical positions.
|
| - * There are no separate phone and tablet UIs; this layout adapts based on the available space.
|
| - */
|
| -public class NewTabPageLayout extends BoundedLinearLayout {
|
| -
|
| - // Space permitting, the spacers will grow from 0dp to the heights given below. If there is
|
| - // additional space, it will be distributed evenly between the top and bottom spacers.
|
| - private static final float TOP_SPACER_HEIGHT_DP = 44f;
|
| - private static final float MIDDLE_SPACER_HEIGHT_DP = 24f;
|
| - private static final float BOTTOM_SPACER_HEIGHT_DP = 44f;
|
| - private static final float TOTAL_SPACER_HEIGHT_DP = TOP_SPACER_HEIGHT_DP
|
| - + MIDDLE_SPACER_HEIGHT_DP + BOTTOM_SPACER_HEIGHT_DP;
|
| -
|
| - private final int mTopSpacerHeight;
|
| - private final int mMiddleSpacerHeight;
|
| - private final int mBottomSpacerHeight;
|
| - private final int mTotalSpacerHeight;
|
| -
|
| - private int mParentScrollViewportHeight;
|
| -
|
| - private View mTopSpacer;
|
| - private View mMiddleSpacer;
|
| - private View mBottomSpacer;
|
| - private View mScrollCompensationSpacer;
|
| -
|
| - /**
|
| - * Constructor for inflating from XML.
|
| - */
|
| - public NewTabPageLayout(Context context, AttributeSet attrs) {
|
| - super(context, attrs);
|
| - float density = getResources().getDisplayMetrics().density;
|
| - mTopSpacerHeight = Math.round(density * TOP_SPACER_HEIGHT_DP);
|
| - mMiddleSpacerHeight = Math.round(density * MIDDLE_SPACER_HEIGHT_DP);
|
| - mBottomSpacerHeight = Math.round(density * BOTTOM_SPACER_HEIGHT_DP);
|
| - mTotalSpacerHeight = Math.round(density * TOTAL_SPACER_HEIGHT_DP);
|
| - }
|
| -
|
| - @Override
|
| - protected void onFinishInflate() {
|
| - super.onFinishInflate();
|
| - mTopSpacer = findViewById(R.id.ntp_top_spacer);
|
| - mMiddleSpacer = findViewById(R.id.ntp_middle_spacer);
|
| - mBottomSpacer = findViewById(R.id.ntp_bottom_spacer);
|
| - mScrollCompensationSpacer = findViewById(R.id.ntp_scroll_spacer);
|
| - }
|
| -
|
| - /**
|
| - * Specifies the height of the scroll viewport for the container view of this View.
|
| - *
|
| - * <p>
|
| - * As this is required in onMeasure, we can not rely on the parent having the proper
|
| - * size set yet and thus must be told explicitly of this size.
|
| - *
|
| - * @param height The height of the scroll viewport containing this view.
|
| - */
|
| - public void setParentScrollViewportHeight(int height) {
|
| - mParentScrollViewportHeight = height;
|
| - }
|
| -
|
| - @Override
|
| - protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
|
| - mScrollCompensationSpacer.getLayoutParams().height = 0;
|
| - super.onMeasure(widthMeasureSpec, heightMeasureSpec);
|
| - distributeExtraSpace(mTopSpacer.getMeasuredHeight());
|
| -
|
| - int minScrollAmountRequired = 0;
|
| - for (int i = 0; i < getChildCount(); i++) {
|
| - View child = getChildAt(i);
|
| -
|
| - MarginLayoutParams layoutParams = (MarginLayoutParams) child.getLayoutParams();
|
| - if (child.getVisibility() != View.GONE) {
|
| - minScrollAmountRequired += layoutParams.topMargin;
|
| - }
|
| -
|
| - if (child.getId() == R.id.most_visited_layout) break;
|
| - if (child.getId() == R.id.opt_out_promo) break;
|
| -
|
| - if (child.getVisibility() != View.GONE) {
|
| - minScrollAmountRequired += child.getMeasuredHeight();
|
| - minScrollAmountRequired += layoutParams.bottomMargin;
|
| - }
|
| - }
|
| -
|
| - int scrollVsHeightDiff = getMeasuredHeight() - mParentScrollViewportHeight;
|
| - if (getMeasuredHeight() > mParentScrollViewportHeight
|
| - && scrollVsHeightDiff < minScrollAmountRequired) {
|
| - mScrollCompensationSpacer.getLayoutParams().height =
|
| - minScrollAmountRequired - scrollVsHeightDiff;
|
| - mScrollCompensationSpacer.setVisibility(View.INVISIBLE);
|
| -
|
| - super.onMeasure(widthMeasureSpec, heightMeasureSpec);
|
| - distributeExtraSpace(mTopSpacer.getMeasuredHeight());
|
| - } else {
|
| - mScrollCompensationSpacer.setVisibility(View.GONE);
|
| - }
|
| - }
|
| -
|
| - /**
|
| - * Distribute extra vertical space between the three spacer views.
|
| - * @param extraHeight The amount of extra space, in pixels.
|
| - */
|
| - private void distributeExtraSpace(int extraHeight) {
|
| - int topSpacerHeight;
|
| - int middleSpacerHeight;
|
| - int bottomSpacerHeight;
|
| -
|
| - if (extraHeight < mTotalSpacerHeight) {
|
| - topSpacerHeight = Math.round(extraHeight
|
| - * (TOP_SPACER_HEIGHT_DP / TOTAL_SPACER_HEIGHT_DP));
|
| - extraHeight -= topSpacerHeight;
|
| - middleSpacerHeight = Math.round(extraHeight * (MIDDLE_SPACER_HEIGHT_DP
|
| - / (MIDDLE_SPACER_HEIGHT_DP + BOTTOM_SPACER_HEIGHT_DP)));
|
| - extraHeight -= middleSpacerHeight;
|
| - bottomSpacerHeight = extraHeight;
|
| - } else {
|
| - topSpacerHeight = mTopSpacerHeight;
|
| - middleSpacerHeight = mMiddleSpacerHeight;
|
| - bottomSpacerHeight = mBottomSpacerHeight;
|
| - extraHeight -= mTotalSpacerHeight;
|
| -
|
| - // Distribute remaining space evenly between the top and bottom spacers.
|
| - topSpacerHeight += (extraHeight + 1) / 2;
|
| - bottomSpacerHeight += extraHeight / 2;
|
| - }
|
| -
|
| - int widthSpec = MeasureSpec.makeMeasureSpec(0, MeasureSpec.EXACTLY);
|
| - mTopSpacer.measure(widthSpec,
|
| - MeasureSpec.makeMeasureSpec(topSpacerHeight, MeasureSpec.EXACTLY));
|
| - mMiddleSpacer.measure(widthSpec,
|
| - MeasureSpec.makeMeasureSpec(middleSpacerHeight, MeasureSpec.EXACTLY));
|
| - mBottomSpacer.measure(widthSpec,
|
| - MeasureSpec.makeMeasureSpec(bottomSpacerHeight, MeasureSpec.EXACTLY));
|
| - }
|
| -}
|
|
|