0

こんにちは、私はアンドロイドが初めてなので、優しくしてください:)、
私はギャラリーを持っています。画像をロードする必要があります。画像がたくさんあります。画像のロード時のパフォーマンスは、AsyncTaskを使用して解決しました。

ギャラリーのスクロールに問題があり、画像がスキップされ、見栄えがよくありません。

カスタム ギャラリーを実装しようとしましたが、成功しませんでした。機能しません
。もう 1 つ質問があります。

final ScrollableGallery galleryView = (ScrollableGallery)findViewById(R.id.gallery); //always returns null

突然ですが、理由を説明していただけますか?

コードは次のとおりです。

import android.content.Context;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.widget.Gallery;

public class ScrollableGallery extends Gallery {

    public ScrollableGallery(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
    }

    public ScrollableGallery(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public ScrollableGallery(Context context) {
        super(context);
    }

    @Override
    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {

        // limit the max speed in either direction
        if (velocityX > 1200.0f) {
            velocityX = 1200.0f;
        } else if (velocityX < 1200.0f) {
            velocityX = -1200.0f;
        }
        return super.onFling(e1, e2, velocityX, velocityY);
    }   
}

XML 部分:

<ScrollableGallery
        android:id="@+id/gallery"
        android:layout_width="675dp"
        android:layout_height="492dp"
        android:layout_marginLeft="62dp"
        android:layout_marginTop="225dp"
        android:scaleType="fitXY" >
    </ScrollableGallery>


アクティビティの呼び出し:
イニシエーション

final ScrollableGallery galleryView = (ScrollableGallery)findViewById(R.id.gallery);


アダプターの開始:

galleryV.setAdapter(new BaseAdapter() {                     
            public int getCount() {             
                return _imageList.size();
            }

            public Object getItem(int position) {
                return _imageList.get(position);
            }

            public long getItemId(int position) {
                _position = position;
                return position;
            }

            public View getView(final int position, View convertView,final ViewGroup parent) {              
                if (convertView == null) {
                    convertView = new ImageView(Database.this);
                }               
                ImageDispatcher dispatch = new ImageDispatcher(((ImageView) convertView));              
                dispatch.execute(_imageList.get(position));                                     
                ((ImageView) convertView).setScaleType(ImageView.ScaleType.FIT_XY);
                ((ImageView) convertView).setLayoutParams(new ScrollableGallery.LayoutParams(675, 492));

                return convertView;
            }           
        });
<br/>
The image dispatcher:

    import java.lang.ref.WeakReference;
    import android.graphics.Bitmap;
    import android.graphics.BitmapFactory;
    import android.os.AsyncTask;
    import android.widget.ImageView;

    public class ImageDispatcher extends AsyncTask<String, Void, Bitmap> {

        private final WeakReference<ImageView> imageViewReference;

        public ImageDispatcher(ImageView imageView) {
            imageViewReference = new WeakReference<ImageView>(imageView);
        }

        @Override
        // Actual download method, run in the task thread
        protected Bitmap doInBackground(String... params) { 

            return ShrinkBitmap(params[0], 300 ,300);
        }

        @Override
        protected void onPostExecute(Bitmap bitmap) {
            if (isCancelled()) {
                bitmap = null;
            }

            if (imageViewReference != null) {
                ImageView imageView = imageViewReference.get();
                if (imageView != null) {
                    imageView.setImageBitmap(bitmap);
                }
            }
        }

        /*********************************************************
         * PRIVATE METHODS 
         *********************************************************/
        @SuppressWarnings("unused")
        private Bitmap ShrinkBitmap(String file, int width, int height) {
            BitmapFactory.Options bmpFactoryOptions = new BitmapFactory.Options();
            bmpFactoryOptions.inTempStorage = new byte[16 * 1024];
            bmpFactoryOptions.inJustDecodeBounds = true;
            Bitmap bitmap = BitmapFactory.decodeFile(file, bmpFactoryOptions);
            int heightRatio = (int) Math.ceil(bmpFactoryOptions.outHeight / (float) height);
            int widthRatio = (int) Math.ceil(bmpFactoryOptions.outWidth / (float) width);

            bmpFactoryOptions.inSampleSize = heightRatio > 1 || widthRatio > 1 ? heightRatio : widthRatio;                  
            bmpFactoryOptions.inJustDecodeBounds = false;
            bitmap = BitmapFactory.decodeFile(file, bmpFactoryOptions);
            return bitmap;
        }

        @SuppressWarnings("unused")
        private Bitmap ShrinkBitmap(String file) {
            BitmapFactory.Options bmpFactoryOptions = new BitmapFactory.Options();
            bmpFactoryOptions.inTempStorage = new byte[16 * 1024];
            bmpFactoryOptions.inJustDecodeBounds = true;

            Bitmap bMap = BitmapFactory.decodeFile(file);       
            Bitmap bMapScaled = Bitmap.createScaledBitmap(bMap,150, 100, true);

            return bMapScaled;
        }
    }

私はこの部分のために私が持っているすべてのコードだと思います、今問題です:
どのようにスクロールを作成し、時間内に1つの画像を作成しますか?

コードの修正は大歓迎です!

前もって感謝します...

4

2 に答える 2

0

XMLでGalleryを宣言する代わりに。

Gallery gallery = new  CustomGaller(getActivity());

RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams  (LayoutParams.FILL_PARENT,LayoutParams.FILL_PARENT);
            params.addRule(RelativeLayout.RIGHT_OF, R.id.left);
            params.addRule(RelativeLayout.LEFT_OF,R.id.right);
            gallery.setLayoutParams(params);
            gallery.setAdapter(new GalleryAdapter(<Pass values>));

View id を CustomGallery に渡す必要はありません。

于 2011-11-25T04:22:03.710 に答える
0

カスタム ギャラリーで

@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,float velocityY) {
    -->> super.onFling(e1, e2, 20, velocityY); <<--

    return false;
}

3 番目のパラメーターを変更してみてください。

于 2011-11-24T09:18:33.663 に答える