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

Unified Diff: chrome/android/java_staging/src/org/chromium/chrome/browser/ntp/MostVisitedThumbnail.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/MostVisitedThumbnail.java
diff --git a/chrome/android/java_staging/src/org/chromium/chrome/browser/ntp/MostVisitedThumbnail.java b/chrome/android/java_staging/src/org/chromium/chrome/browser/ntp/MostVisitedThumbnail.java
deleted file mode 100644
index 0d3edc6ac7234e2111489ccf687adcdc6a4d8190..0000000000000000000000000000000000000000
--- a/chrome/android/java_staging/src/org/chromium/chrome/browser/ntp/MostVisitedThumbnail.java
+++ /dev/null
@@ -1,97 +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.Bitmap;
-import android.graphics.Color;
-import android.graphics.Matrix;
-import android.util.AttributeSet;
-import android.widget.ImageView;
-
-import org.chromium.chrome.R;
-
-/**
- * Displays a thumbnail for a most visited item on the NTP.
- */
-public class MostVisitedThumbnail extends ImageView {
-
- private final int mDesiredWidth;
- private final int mDesiredHeight;
- private Bitmap mThumbnail;
- private Matrix mImageMatrix;
-
- /**
- * Constructor for inflating from XML.
- */
- public MostVisitedThumbnail(Context context, AttributeSet attrs) {
- super(context, attrs);
- Resources res = getResources();
- mDesiredWidth = res.getDimensionPixelSize(R.dimen.most_visited_thumbnail_width);
- mDesiredHeight = res.getDimensionPixelSize(R.dimen.most_visited_thumbnail_height);
- }
-
- /**
- * Updates the thumbnail and trigger a redraw with the new thumbnail.
- */
- void setThumbnail(Bitmap thumbnail) {
- mThumbnail = thumbnail;
- if (thumbnail != null) {
- setImageBitmap(thumbnail);
- setScaleType(ImageView.ScaleType.MATRIX);
- updateThumbnailMatrix();
- } else {
- setBackgroundColor(Color.WHITE);
- setImageResource(R.drawable.most_visited_thumbnail_placeholder);
- setScaleType(ImageView.ScaleType.CENTER);
- }
- }
-
- /**
- * Updates the matrix used to scale the thumbnail when drawing it. This needs to be called
- * whenever the thumbnail changes or this view's size changes.
- *
- * This matrix ensures that the thumbnail is anchored at the top left corner of this view and
- * is scaled as small as possible while still covering the entire view. Surprisingly, there's
- * no way to get this behavior using the other ImageView.ScaleTypes.
- */
- private void updateThumbnailMatrix() {
- if (mThumbnail == null) return;
-
- if (mImageMatrix == null) mImageMatrix = new Matrix();
- float widthScale = (float) getMeasuredWidth() / mThumbnail.getWidth();
- float heightScale = (float) getMeasuredHeight() / mThumbnail.getHeight();
- float scale = Math.max(widthScale, heightScale);
- mImageMatrix.setScale(scale, scale);
- setImageMatrix(mImageMatrix);
- }
-
- @Override
- protected void onSizeChanged(int w, int h, int oldw, int oldh) {
- super.onSizeChanged(w, h, oldw, oldh);
- updateThumbnailMatrix();
- }
-
- /**
- * Maintains this view's aspect ratio, even when its width is constrained. We can't just use
- * android:adjustViewBounds, since that won't work when the source drawable isn't set or when
- * it's the "missing thumbnail" gray circle, which has a different aspect ratio than thumbnails.
- */
- @Override
- protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
- int width = resolveSize(mDesiredWidth, widthMeasureSpec);
- int height;
- if (width == mDesiredWidth) {
- height = mDesiredHeight;
- } else {
- // The width is fixed. Find the height that keeps the proper aspect ratio.
- height = Math.round((float) mDesiredHeight / mDesiredWidth * width);
- height = resolveSize(height, heightMeasureSpec);
- }
- super.onMeasure(MeasureSpec.makeMeasureSpec(width, MeasureSpec.EXACTLY),
- MeasureSpec.makeMeasureSpec(height, MeasureSpec.EXACTLY));
- }
-}

Powered by Google App Engine
This is Rietveld 408576698