我有一个非常奇怪的问题,我似乎无法解决。
我似乎无法为 ScrollView 内的 ImageView 调整位图的大小。我测试了相同的布局(但没有滚动),并且图像的大小按照应有的方式调整。
我发现其他人有这种问题,对于大多数使用android:fillViewport="true"
就足够了,但对我来说不起作用。
这是我的布局:
<?xml version="1.0" encoding="utf-8"?>
<ScrollView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:fillViewport="true"
android:background="@drawable/bg_app" >
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_margin="5dp"
android:background="@drawable/custom_white_background"
android:padding="5dp">
<ImageView
android:id="@+id/full_image_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:adjustViewBounds="true"
android:scaleType="fitCenter"
android:src="@drawable/bg_app"
android:contentDescription="@string/otl_img_description"
android:layout_margin="5dp"
android:padding="5dp" />
<View
android:id="@+id/divider2"
android:layout_width="match_parent"
android:layout_height="3dp"
android:layout_below="@+id/full_image_view"
android:layout_centerHorizontal="true"
android:layout_marginLeft="5dp"
android:paddingRight="5dp"
android:layout_marginRight="5dp"
android:paddingLeft="5dp"
android:alpha="0.3"
android:background="@color/black_50"
android:fadingEdge="horizontal" />
<TextView
android:id="@+id/onthelist_animal_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_alignParentLeft="true"
android:layout_below="@+id/full_image_view"
android:layout_margin="5dp"
android:layout_toLeftOf="@+id/onthelist_animal_date"
android:gravity="left|center"
android:padding="5dp"
android:text="@string/otl_animal_name"
android:textColor="@color/blue"
android:textStyle="bold"
android:textSize="18sp" />
<TextView
android:id="@+id/onthelist_animal_date"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/full_image_view"
android:layout_centerHorizontal="true"
android:layout_margin="5dp"
android:gravity="center"
android:padding="5dp"
android:text="@string/otl_animal_date"
android:textColor="#a00000"
android:textStyle="bold"
android:textSize="18sp" />
<ImageButton
android:id="@+id/onthelist_share"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@+id/onthelist_animal_date"
android:layout_alignParentBottom="true"
android:layout_alignParentRight="true"
android:layout_alignTop="@+id/onthelist_animal_date"
android:layout_toRightOf="@+id/onthelist_animal_date"
android:adjustViewBounds="true"
android:paddingRight="5dp"
android:contentDescription="@string/otl_animal_share"
android:scaleType="fitEnd"
android:src="@android:drawable/ic_menu_share"
android:background="@android:color/transparent" />
</RelativeLayout>
<Button
android:id="@+id/onthelist_save"
style="@style/ButtonText"
android:layout_height="wrap_content"
android:background="@layout/custom_red_button"
android:text="@string/otl_save"
android:layout_margin="5dp"
android:padding="5dp" />
<TextView
android:id="@+id/onthelist_animal_description"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="5dp"
android:background="@drawable/custom_white_background"
android:padding="5dp"
android:textAppearance="?android:attr/textAppearanceSmall"
android:textColor="@color/black"
android:text="@string/otl_animal_description"
android:linksClickable="true" />
</LinearLayout>
</ScrollView>
我正在为 ImageView 设置图像,full_image_view
如下所示:
imageView = (ImageView) findViewById(R.id.full_image_view);
Log.i("OnTheList", "itemID[FI] = " + position);
try {
imageView.setImageBitmap(new ImageLoadTask().execute(
JSONParserOnTheList.ANIMALS.get(position).photo).get());
} catch (InterruptedException e) {
imageView.setImageResource(R.drawable.default_photo);
e.printStackTrace();
} catch (ExecutionException e) {
imageView.setImageResource(R.drawable.default_photo);
e.printStackTrace();
}
AsyncTask 返回一个位图。
谢谢你。
编辑(解决方案-> 修复)
在应用了许多尝试解决问题的事情和方法之后,我找到了解决方案。这个想法是布局工作正常,问题是在某些设备上,由于像素密度,图像在较小的版本中调整大小。
当我解码位图时,我应用的修复直接在 asynctask 中。
所以布局和其他一切都保持不变,asyntask 是这样的:
private class ImageLoadTask extends AsyncTask<String, Void, Bitmap> {
private Bitmap bitmap;
@Override
protected void onPreExecute() {
loading.setTitle("Loading image ...");
loading.show();
super.onPreExecute();
}
@Override
protected Bitmap doInBackground(String... params) {
try {
URL url;
url = new URL(params[0]);
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setDoInput(true);
connection.connect();
InputStream input = connection.getInputStream();
BitmapFactory.Options options = new BitmapFactory.Options();
// Bitmap scale depending on density
// For example:
// 1600*1200 image to be resized to 640*480
// (1600*2 equal to 640*5)
options.inDensity = 5;
options.inTargetDensity = 2;
options.inScaled = false;
// Decode the bitmap
bitmap = BitmapFactory.decodeStream(input, null, options);
input.close();
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return bitmap;
}
@Override
protected void onPostExecute(Bitmap result) {
loading.dismiss();
loading.cancel();
super.onPostExecute(result);
}
}
请注意,选项BitmapFactory
是解决问题的重要部分。
此外,如果没有非常大的图像(又名全尺寸图像),您可以根据屏幕大小提供尺寸,如下所示:
ImageView imageView = (ImageView) findViewById(R.id.full_image_view);
imageView.setMaxHeight(screenSize()[0]-150);
imageView.setMaxWidth(screenSize()[1]-150);
private int[] screenSize() {
DisplayMetrics metrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(metrics);
int height = metrics.heightPixels;
int width = metrics.widthPixels;
return new int[] {height, width};
希望这对将来遇到此问题的人有所帮助。}