Отображение изображения пользовательского размера Universal ImageLoader

Я использую Universal ImageLoader для загрузки больших изображений с сервера и отображения их в режиме обложки. Проблема, с которой я столкнулся, заключается в том, что я не могу установить нестандартный размер для своего изображения. Просто занимает весь экран. Например, я загружаю изображение размером 500 x 1200 и хочу отобразить его размером 300 x 300. Но оно занимает весь экран. Пожалуйста, помогите мне с этой проблемой, так как я застрял в течение более 3 дней. Спасибо.

Код

public class HomeCoverFlow {

    Context mContext;
    public CoverFlow coverFlow;
    ImageAdapter coverImageAdapter;
    ImageLoader imageLoader = ImageLoader.getInstance();
    DisplayImageOptions options;

     /** Called when the activity is first created. */

    public HomeCoverFlow(Context context)
    {
        mContext = context;
           options = new DisplayImageOptions.Builder()
           .showImageOnLoading(R.drawable.flyer_placeholder)
           .showImageForEmptyUri(R.drawable.flyer_placeholder)
           .imageScaleType(ImageScaleType.EXACTLY)
           .cacheInMemory(true)
           .build();

         coverFlow = new CoverFlow(context);

         coverImageAdapter =  new ImageAdapter(mContext);

         coverFlow.setAdapter(coverImageAdapter);

         coverFlow.setSpacing(-25);
         coverFlow.setSelection(2, true);
         coverFlow.setAnimationDuration(1000);

         coverFlow.setGravity(Gravity.CENTER_VERTICAL);


            // HEIGHT
            coverImageAdapter.coverflowHeight = 100; //display.getHeight() / 3;

            //WIDTH
            coverImageAdapter.coverflowWidth = 100;// display.getWidth() / 2;


        }

Метод в адаптере для создания представлений элементов. Здесь я использую загрузчик изображений для загрузки изображения и отображения

public View getView(int position, View convertView, ViewGroup parent) {

         FeaturedFlyerData data = (FeaturedFlyerData) getItem(position);

             if(data.flyerImage == null)
             {
                 setNewImage(position);
             }
             //see text or image
             if(data.displayImage)
             {
                 data.flyerImage.setBackgroundColor(Color.BLACK);

                 imageLoader.displayImage(data.url, data.flyerImage, options, null);

             }


         return data.flyerImage;

}       

void setNewImage(int position)
     {
         FeaturedFlyerData data = (FeaturedFlyerData) getItem(position);

         data.flyerImage = new ImageView(mContext);
         data.flyerImage.layout(0, 10, 200,350);
         data.flyerImage.setScaleType(ScaleType.CENTER_INSIDE);
         data.flyerImage.setTag(Integer.toString(position));
         data.flyerImage.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View v) {

            imageClicked(Integer.parseInt(v.getTag().toString()));

        }
    });
    }

}

Я не знаю, какой еще фрагмент кода предоставить здесь. Пожалуйста, прокомментируйте, если вам нужны дополнительные разъяснения. Спасибо.


person NightFury    schedule 25.02.2014    source источник
comment
data.flyerImage - это ImageView, верно? Вы пытались установить layout_height и layout_width этого ImageView?   -  person Glauco Neves    schedule 25.02.2014
comment
@GlaucoNeves да, это изображение. Я уже установил метод setNewImage. Смотрите мою правку. Я делаю это правильно?   -  person NightFury    schedule 25.02.2014
comment
Попробуйте data.flyerImage.getLayoutParams().height = 100; data.flyerImage.getLayoutParams().width = 100;   -  person Glauco Neves    schedule 25.02.2014
comment
@GlaucoNeves Я получаю nullpointerexception за это. Может быть, это недействительно для изображений.   -  person NightFury    schedule 25.02.2014
comment
Возможно, это поможет stackoverflow.com/questions/3144940 /   -  person Glauco Neves    schedule 25.02.2014
comment
Есть ли причина, по которой вы не используете макет xml для отображения изображения?   -  person WarrenFaith    schedule 25.02.2014
comment
@WarrenFaith, потому что я использую обложку, и она получена из виджета галереи, который просто отображает элементы изображения.   -  person NightFury    schedule 25.02.2014
comment
@GlaucoNeves по-прежнему выдается исключение .. java.lang.ClassCastException: android.widget.LinearLayout$LayoutParams cannot be cast to android.widget.Gallery$LayoutParams   -  person NightFury    schedule 25.02.2014
comment
Ну, для этой конкретной ошибки вы можете изменить, где у вас есть параметры GalleryLayoutParams, на LinearLayoutParams   -  person kabuto178    schedule 25.02.2014
comment
Это сработало для меня. Спасибо вам, ребята. Я установил параметры макета для виджета галереи, а не для linearlayout.   -  person NightFury    schedule 26.02.2014


Ответы (1)


Я использую следующий код для отображения изображений нестандартного размера в обложке с использованием универсального загрузчика изображений.

В конструкторе установите DisplayImageOptions как:

DisplayImageOptions options = new DisplayImageOptions.Builder()
      .showImageOnLoading(R.drawable.flyer_placeholder)
      .showImageForEmptyUri(R.drawable.flyer_placeholder)
      .imageScaleType(ImageScaleType.EXACTLY)
      .cacheInMemory(true)
      .build();

//set coverflow full screen, and images size.

         coverFlow.setSpacing(-25);
         coverFlow.setAnimationDuration(1000);
         coverFlow.setGravity(Gravity.CENTER_VERTICAL);
         coverFlow.setLayoutParams(new CoverFlow.LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT));

         // GET SCREEN SIZE
            WindowManager wm = (WindowManager) mContext.getSystemService(Context.WINDOW_SERVICE);
            Display display = wm.getDefaultDisplay();

            DisplayMetrics dm = new DisplayMetrics();
            display.getMetrics(dm);

//Here I am setting image size using my custom adapter in "dp". Avoid to use pixels as things will mess up for different screen sizes

            coverImageAdapter.coverflowWidth = (int) Math.ceil(dm.widthPixels * (dm.densityDpi / 160.0));
            coverImageAdapter.coverflowHeight = (int) Math.ceil(dm.heightPixels * (dm.densityDpi / 160.0)) / 2;

В методе setNewImage адаптера (вызываемом в getView) используйте Gallery.LayoutParams:

void setNewImage(int position)
 {
     FeaturedFlyerData data = (FeaturedFlyerData) getItem(position);

     data.flyerImage = new ImageView(mContext);      
     data.flyerImage.setLayoutParams(new Gallery.LayoutParams(coverflowWidth, coverflowHeight));
     data.flyerImage.setScaleType(ScaleType.CENTER_INSIDE);
}
person NightFury    schedule 28.02.2014