Correctly populate FeatureImage with app.featureGraphic
.
Fall back to extracting the colour from the apps icon if that is all that is available.
This commit is contained in:
parent
5aa44a4d74
commit
8cfe1d3584
@ -9,8 +9,6 @@ import android.content.DialogInterface;
|
|||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.pm.PackageInfo;
|
import android.content.pm.PackageInfo;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.graphics.Bitmap;
|
|
||||||
import android.graphics.Color;
|
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.support.design.widget.AppBarLayout;
|
import android.support.design.widget.AppBarLayout;
|
||||||
@ -18,7 +16,6 @@ import android.support.design.widget.CoordinatorLayout;
|
|||||||
import android.support.v4.content.LocalBroadcastManager;
|
import android.support.v4.content.LocalBroadcastManager;
|
||||||
import android.support.v7.app.AlertDialog;
|
import android.support.v7.app.AlertDialog;
|
||||||
import android.support.v7.app.AppCompatActivity;
|
import android.support.v7.app.AppCompatActivity;
|
||||||
import android.support.v7.graphics.Palette;
|
|
||||||
import android.support.v7.widget.LinearLayoutManager;
|
import android.support.v7.widget.LinearLayoutManager;
|
||||||
import android.support.v7.widget.RecyclerView;
|
import android.support.v7.widget.RecyclerView;
|
||||||
import android.support.v7.widget.Toolbar;
|
import android.support.v7.widget.Toolbar;
|
||||||
@ -26,13 +23,10 @@ import android.text.TextUtils;
|
|||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.Menu;
|
import android.view.Menu;
|
||||||
import android.view.MenuItem;
|
import android.view.MenuItem;
|
||||||
import android.view.View;
|
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
import com.nostra13.universalimageloader.core.DisplayImageOptions;
|
import com.nostra13.universalimageloader.core.DisplayImageOptions;
|
||||||
import com.nostra13.universalimageloader.core.ImageLoader;
|
import com.nostra13.universalimageloader.core.ImageLoader;
|
||||||
import com.nostra13.universalimageloader.core.assist.FailReason;
|
|
||||||
import com.nostra13.universalimageloader.core.listener.ImageLoadingListener;
|
|
||||||
|
|
||||||
import org.fdroid.fdroid.data.Apk;
|
import org.fdroid.fdroid.data.Apk;
|
||||||
import org.fdroid.fdroid.data.ApkProvider;
|
import org.fdroid.fdroid.data.ApkProvider;
|
||||||
@ -136,39 +130,10 @@ public class AppDetails2 extends AppCompatActivity implements ShareChooserDialog
|
|||||||
recyclerView.setAdapter(adapter);
|
recyclerView.setAdapter(adapter);
|
||||||
|
|
||||||
// Load the feature graphic, if present
|
// Load the feature graphic, if present
|
||||||
|
final FeatureImage featureImage = (FeatureImage) findViewById(R.id.feature_graphic);
|
||||||
|
DisplayImageOptions displayImageOptions = Utils.getImageLoadingOptions().build();
|
||||||
String featureGraphicUrl = app.getFeatureGraphicUrl(this);
|
String featureGraphicUrl = app.getFeatureGraphicUrl(this);
|
||||||
if (!TextUtils.isEmpty(featureGraphicUrl)) {
|
featureImage.loadImageAndDisplay(ImageLoader.getInstance(), displayImageOptions, featureGraphicUrl, app.iconUrl);
|
||||||
final FeatureImage featureImage = (FeatureImage) findViewById(R.id.feature_graphic);
|
|
||||||
DisplayImageOptions displayImageOptions = Utils.getImageLoadingOptions().build();
|
|
||||||
ImageLoader.getInstance().loadImage(featureGraphicUrl, displayImageOptions, new ImageLoadingListener() {
|
|
||||||
@Override
|
|
||||||
public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
|
|
||||||
if (featureImage != null) {
|
|
||||||
new Palette.Builder(loadedImage).generate(new Palette.PaletteAsyncListener() {
|
|
||||||
@Override
|
|
||||||
public void onGenerated(Palette palette) {
|
|
||||||
featureImage.setColour(palette.getDominantColor(Color.LTGRAY));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onLoadingStarted(String imageUri, View view) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onLoadingFailed(String imageUri, View view, FailReason failReason) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onLoadingCancelled(String imageUri, View view) {
|
|
||||||
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private String getPackageNameFromIntent(Intent intent) {
|
private String getPackageNameFromIntent(Intent intent) {
|
||||||
|
@ -3,6 +3,7 @@ package org.fdroid.fdroid.views.apps;
|
|||||||
import android.animation.ValueAnimator;
|
import android.animation.ValueAnimator;
|
||||||
import android.annotation.TargetApi;
|
import android.annotation.TargetApi;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.graphics.Bitmap;
|
||||||
import android.graphics.Canvas;
|
import android.graphics.Canvas;
|
||||||
import android.graphics.Color;
|
import android.graphics.Color;
|
||||||
import android.graphics.Paint;
|
import android.graphics.Paint;
|
||||||
@ -11,10 +12,18 @@ import android.graphics.Point;
|
|||||||
import android.graphics.PorterDuff;
|
import android.graphics.PorterDuff;
|
||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.support.annotation.ColorInt;
|
import android.support.annotation.ColorInt;
|
||||||
|
import android.support.annotation.NonNull;
|
||||||
import android.support.annotation.Nullable;
|
import android.support.annotation.Nullable;
|
||||||
import android.support.v7.graphics.Palette;
|
import android.support.v7.graphics.Palette;
|
||||||
import android.support.v7.widget.AppCompatImageView;
|
import android.support.v7.widget.AppCompatImageView;
|
||||||
|
import android.text.TextUtils;
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
|
import android.view.View;
|
||||||
|
|
||||||
|
import com.nostra13.universalimageloader.core.DisplayImageOptions;
|
||||||
|
import com.nostra13.universalimageloader.core.ImageLoader;
|
||||||
|
import com.nostra13.universalimageloader.core.assist.FailReason;
|
||||||
|
import com.nostra13.universalimageloader.core.listener.ImageLoadingListener;
|
||||||
|
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
|
|
||||||
@ -225,4 +234,52 @@ public class FeatureImage extends AppCompatImageView {
|
|||||||
|
|
||||||
return path;
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void loadImageAndDisplay(@NonNull ImageLoader loader, @NonNull DisplayImageOptions imageOptions, @Nullable String featureImageToShow, @Nullable String fallbackImageToExtractColours) {
|
||||||
|
if (!TextUtils.isEmpty(featureImageToShow)) {
|
||||||
|
loadImageAndDisplay(loader, imageOptions, featureImageToShow);
|
||||||
|
} else if (!TextUtils.isEmpty(fallbackImageToExtractColours)) {
|
||||||
|
loadImageAndExtractColour(loader, imageOptions, fallbackImageToExtractColours);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void loadImageAndExtractColour(@NonNull ImageLoader loader, @NonNull DisplayImageOptions imageOptions, String url) {
|
||||||
|
loader.loadImage(url, imageOptions, new ImageLoadingAdapter() {
|
||||||
|
@Override
|
||||||
|
public void onLoadingComplete(String imageUri, View view, final Bitmap loadedImage) {
|
||||||
|
if (loadedImage != null) {
|
||||||
|
new Palette.Builder(loadedImage).generate(new Palette.PaletteAsyncListener() {
|
||||||
|
@Override
|
||||||
|
public void onGenerated(Palette palette) {
|
||||||
|
if (palette != null) {
|
||||||
|
setColour(palette.getDominantColor(Color.LTGRAY));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public void loadImageAndDisplay(@NonNull ImageLoader loader, @NonNull DisplayImageOptions imageOptions, String url) {
|
||||||
|
loader.loadImage(url, imageOptions, new ImageLoadingAdapter() {
|
||||||
|
@Override
|
||||||
|
public void onLoadingComplete(String imageUri, View view, final Bitmap loadedImage) {
|
||||||
|
if (loadedImage != null) {
|
||||||
|
setImageBitmap(loadedImage);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private abstract static class ImageLoadingAdapter implements ImageLoadingListener {
|
||||||
|
@Override
|
||||||
|
public void onLoadingStarted(String imageUri, View view) { }
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onLoadingFailed(String imageUri, View view, FailReason failReason) { }
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onLoadingCancelled(String imageUri, View view) { }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -13,6 +13,7 @@ import android.support.v4.app.ActivityOptionsCompat;
|
|||||||
import android.support.v4.util.Pair;
|
import android.support.v4.util.Pair;
|
||||||
import android.support.v7.graphics.Palette;
|
import android.support.v7.graphics.Palette;
|
||||||
import android.support.v7.widget.RecyclerView;
|
import android.support.v7.widget.RecyclerView;
|
||||||
|
import android.text.TextUtils;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
@ -110,12 +111,23 @@ public class AppCardController extends RecyclerView.ViewHolder implements ImageL
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ImageLoader.getInstance().displayImage(app.iconUrl, icon, displayImageOptions, this);
|
||||||
|
|
||||||
if (featuredImage != null) {
|
if (featuredImage != null) {
|
||||||
featuredImage.setColour(0);
|
featuredImage.setColour(0);
|
||||||
featuredImage.setImageDrawable(null);
|
featuredImage.setImageDrawable(null);
|
||||||
}
|
|
||||||
|
|
||||||
ImageLoader.getInstance().displayImage(app.iconUrl, icon, displayImageOptions, this);
|
// Note: We could call the convenience function loadImageAndDisplay(ImageLoader, DisplayImageOptions, String, String)
|
||||||
|
// which includes a fallback for when currentApp.featureGraphic is empty. However we need
|
||||||
|
// to take care of also loading the icon (regardless of whether there is a featureGraphic
|
||||||
|
// or not for this app) so that we can display the icon to the user. We will use the
|
||||||
|
// load complete listener for the icon to decide whether we need to extract the colour
|
||||||
|
// from that icon and assign to the `FeatureImage` (or whether we should wait for the
|
||||||
|
// feature image to be loaded).
|
||||||
|
if (!TextUtils.isEmpty(app.featureGraphic)) {
|
||||||
|
featuredImage.loadImageAndDisplay(ImageLoader.getInstance(), displayImageOptions, app.featureGraphic);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -145,12 +157,14 @@ public class AppCardController extends RecyclerView.ViewHolder implements ImageL
|
|||||||
// Icon loader callbacks
|
// Icon loader callbacks
|
||||||
//
|
//
|
||||||
// Most are unused, the main goal is to specify a background colour for the featured image if
|
// Most are unused, the main goal is to specify a background colour for the featured image if
|
||||||
// no featured image is specified in the apps metadata.
|
// no featured image is specified in the apps metadata. If an image is specified, then it will
|
||||||
|
// get loaded using the `FeatureImage.loadImageAndDisplay()` method and so we don't need to do
|
||||||
|
// anything special here.
|
||||||
// =============================================================================================
|
// =============================================================================================
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
|
public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
|
||||||
if (featuredImage != null && loadedImage != null) {
|
if (currentApp != null && TextUtils.isEmpty(currentApp.featureGraphic) && featuredImage != null && loadedImage != null) {
|
||||||
new Palette.Builder(loadedImage).generate(new Palette.PaletteAsyncListener() {
|
new Palette.Builder(loadedImage).generate(new Palette.PaletteAsyncListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onGenerated(Palette palette) {
|
public void onGenerated(Palette palette) {
|
||||||
|
@ -12,6 +12,8 @@
|
|||||||
android:layout_width="0dp"
|
android:layout_width="0dp"
|
||||||
android:layout_height="120dp"
|
android:layout_height="120dp"
|
||||||
tools:src="@color/fdroid_green"
|
tools:src="@color/fdroid_green"
|
||||||
|
android:scaleType="centerCrop"
|
||||||
|
android:fitsSystemWindows="true"
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
app:layout_constraintEnd_toEndOf="parent"
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
app:layout_constraintTop_toTopOf="parent" />
|
app:layout_constraintTop_toTopOf="parent" />
|
||||||
|
Loading…
x
Reference in New Issue
Block a user