设备旋转后ImageView很小

时间:2015-01-13 13:34:11

标签: android gridview rotation imageview android-viewholder

旋转设备后 - >图像(id=list_image2)与portrate模式一样小  似乎是因为我改变了列的数量gridView.setNumColumns(3);,但是视图仍然包含以前的宽度和高度的前一个imageview,我也尝试制作gridView.invalidate();在onConfigurationChanged ...但没有结果

添加到Manifest中的活动

  android:configChanges="keyboardHidden|orientation|screenSize"

这是item_grid.xml

<?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/list_row_root"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:orientation="horizontal"
        android:paddingLeft="1dip"
        android:paddingRight="1dip"


 <ImageView
     android:id="@+id/list_image2"
     android:layout_width="fill_parent"
     android:layout_height="wrap_content"
     android:layout_centerInParent="true"
     android:minWidth="@dimen/grid_item_width"
     android:minHeight="@dimen/grid_item_height"
     android:src="@drawable/ic_action_cloud"
     android:scaleType="fitXY"
    />

    <ProgressBar
        android:id="@+id/progressBar1"
        style="?android:attr/progressBarStyleLarge"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="30dp"

        android:layout_alignBottom="@+id/list_image2"
        android:layout_alignTop="@+id/list_image2"
        android:layout_centerHorizontal="true" />

    <RelativeLayout
        android:id="@+id/likes_RelativeLayout"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/field_likes"
        android:paddingTop="5dp"
        android:paddingBottom="5dp"
        android:paddingLeft="10dp"
        android:paddingRight="10dp"
        android:layout_alignBottom="@+id/list_image2"
        android:layout_alignRight="@+id/list_image2"
        android:layout_marginRight="4dp"
        android:layout_marginBottom="4dp" >

        <TextView
            android:id="@+id/likes"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerVertical="true"
            android:textColor="@android:color/white"
            android:text="265465" />

         <ImageView
             android:id="@+id/btn_favoutites"
             android:layout_width="25dp"
             android:layout_height="25dp"
             android:layout_centerVertical="true"
             android:layout_marginLeft="5dp"
             android:layout_toRightOf="@+id/likes"
             android:src="@drawable/btn_rating_star_on_normal_holo_dark"
             android:text="Button" />

    </RelativeLayout>

    <RelativeLayout
        android:id="@+id/btn_RelativeLayout"
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:layout_alignBottom="@+id/likes_RelativeLayout"
        android:layout_alignLeft="@+id/likes_RelativeLayout"
        android:layout_alignRight="@+id/likes_RelativeLayout"
        android:layout_alignTop="@+id/likes_RelativeLayout"
        android:background="@drawable/field_like_clickable_style" >

    </RelativeLayout>

这是我的适配器:

publ

ic class LazyAdapter2 extends BaseAdapter{
    public LazyAdapter2(Context context, ArrayList<WallImage> d) {

            mContext = context;
            data=d;
            inflater = (LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);

            imageLoader = ImageLoader.getInstance();
            options = new DisplayImageOptions.Builder()
                .cacheInMemory(true)
                .cacheOnDisk(true)
                .resetViewBeforeLoading(true)
                .imageScaleType(ImageScaleType.EXACTLY)// default
                .build();
        }

 public View getView( int position,  View convertView, ViewGroup parent) {
         final ViewHolderItem viewHolder;
        if(convertView==null)
        {
             convertView = inflater.inflate(R.layout.item_grid, null);
             viewHolder = new ViewHolderItem();
             viewHolder.thumb_image=(ImageView)convertView.findViewById(R.id.list_image2); // thumb image
             convertView.setTag(viewHolder);

        }else{
            viewHolder = (ViewHolderItem) convertView.getTag();
        }


        WallImage imageObject = data.get(position);
        viewHolder.likes.setText(imageObject.views);
        imageLoader.displayImage(imageObject.preview, viewHolder.thumb_image, options);

        return convertView;
    }

}

enter image description here

4 个答案:

答案 0 :(得分:0)

不仅仅是无效,而是使用 Handler.post()这样怎么样?:

new Handler(getMainLooper()).post(new Runnable() {
    @Override
    public void run() {
        gridView.invalidate();
    }
});

答案 1 :(得分:0)

也许这是因为convertView方法中使用了getView? 它保留了原始布局,并且在方向更改时不会重新创建它。

您可以向ViewHolderItem class添加一个指示屏幕方向的布尔成员。

当您回收视图时,您需要测试viewHolder方向。如果它与当前屏幕方向不同,请不要回收它。

答案 2 :(得分:0)

通过更改item_grid.xml

解决
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/list_row_root"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:gravity="center"
    android:orientation="horizontal"
    android:paddingLeft="1dip"
    android:paddingRight="1dip"
     >
     <ImageView
            android:id="@+id/list_image2"
            android:layout_width="match_parent"
            android:layout_height="@dimen/grid_item_height"
            android:layout_alignParentTop="true"
            android:layout_centerHorizontal="true"
            android:scaleType="centerCrop"
            android:src="@android:color/transparent"
             />
执行ImageView后{p> android:layout_height="@dimen/grid_item_height" =&gt;屏幕图像大小旋转后保持不变,但要在ImageView中调整imege大小,我使用android:scaleType="centerCrop"后图像被轻微切割,但问题解决了

答案 3 :(得分:0)

试试imageScaleType(ImageScaleType.IN_SAMPLE_INT)

imageLoader.displayImage(imageObject.preview, viewHolder.thumb_image, options);
viewHolder.thumb_image.setScaleType(ImageView.ScaleType.FILL_XY);