Ich habe eine Html.ImageGetter Klasse, die ich mit Universal Image Loader zum Laden von Bildern in <img> Tags enthält in einer HTML-JSON-Datei, die ich online abrufen.Wie auf Klicks auf gezeichnete Bilder in Html.ImageGetter Klasse
Die Bilder laden sich ziemlich gut, aber bei kleineren Geräten werden die Bilder verkleinert, um sie an die Breite des Geräts anzupassen, wodurch einige Bilder zu klein sind, um den Inhalt zu sehen.
mein Zweck war es, einen Klick-Listener auf die Bilder zu setzen und einen Zoom-Dialog anzuzeigen, wo der Benutzer die volle Größe des Bildes sehen kann. Momentan fällt es mir schwer, auf Klicks zu warten.
Das ist meine ImageGetter Klasse
public class UILImageGetter implements Html.ImageGetter{
Context c;
TextView container;
UrlImageDownloader urlDrawable;
public UILImageGetter(View textView, Context context) {
this.c = context;
this.container = (TextView) textView;
}
@Override
public Drawable getDrawable(String source) {
urlDrawable = new UrlImageDownloader(c.getResources(), source);
if (Build.VERSION.SDK_INT >= 21) {
urlDrawable.mDrawable = c.getResources().getDrawable(R.drawable.default_thumb,null);
} else {
urlDrawable.mDrawable = c.getResources().getDrawable(R.drawable.default_thumb);
}
ImageLoader.getInstance().loadImage(source, new SimpleListener(urlDrawable));
return urlDrawable;
}
private class SimpleListener extends SimpleImageLoadingListener {
UrlImageDownloader mUrlImageDownloader;
public SimpleListener(UrlImageDownloader downloader) {
super();
mUrlImageDownloader= downloader;
}
@Override
public void onLoadingStarted(String imageUri, View view) {
Log.d("DEBUG", "onLoadingStarted called");
//spinner.setVisibility(View.VISIBLE);
}
@Override
public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
//spinner.setVisibility(View.GONE);
int width = loadedImage.getWidth();
int height = loadedImage.getHeight();
int newWidth = width;
int newHeight = height;
if (width > container.getWidth()) {
newWidth = container.getWidth();
newHeight = (newWidth * height)/width;
}
if (view != null) {
container.getLayoutParams().width = newWidth;
container.getLayoutParams().height = newHeight;
}
Drawable result = new BitmapDrawable(c.getResources(), loadedImage);
result.setBounds(0, 0, newWidth, newHeight);
mUrlImageDownloader.setBounds(1, 1, newWidth, newHeight);
mUrlImageDownloader.mDrawable = result;
container.invalidate();
container.setText(container.getText());
if (view != null) {
//Don't know if this is the right place to listener for clicks but it ain't working
view.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Log.d("TheImage", "Image Clicked");
}
});
}
}
@Override
public void onLoadingFailed(String imageUri, View view, FailReason failReason) {
String message = null;
switch (failReason.getType()) {
case IO_ERROR:
message = "Input/Output error";
break;
case DECODING_ERROR:
message = "Image can't be decoded";
break;
case NETWORK_DENIED:
message = "Downloads are denied";
break;
case OUT_OF_MEMORY:
message = "Out Of Memory error";
break;
case UNKNOWN:
message = "Unknown error";
break;
}
// Toast.makeText(view.getContext(), message, Toast.LENGTH_SHORT).show();
Log.w("UILImageGetter", message);
//spinner.setVisibility(View.GONE);
}
}
private class UrlImageDownloader extends BitmapDrawable {
public Drawable mDrawable;
public UrlImageDownloader(Resources resources, String filepath) {
super(resources, filepath);
mDrawable = new BitmapDrawable(resources, filepath);
}
@Override
public void draw(Canvas canvas) {
if (mDrawable != null) {
mDrawable.draw(canvas);
}
}
}
}
bitten Sie mir dabei helfen könnten?
Danke, das hat es behoben. – X09