私は修正できないように見える非常に奇妙な問題を抱えています。
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>
そして、私は次のfull_image_view
ように ImageView の画像を設定しています:
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 に直接適用されました。
したがって、レイアウトと他のすべては同じままで、非同期タスクは次のとおりです。
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};
これが将来これに苦労する人に役立つことを願っています。}