gpt4 book ai didi

Android:扫描目录并显示图片(缩略图)(图片不存储在媒体存储中)

转载 作者:太空宇宙 更新时间:2023-11-03 10:26:10 25 4
gpt4 key购买 nike

我最近使用我使用媒体查询和媒体存储设计的自定义画廊对显示图片进行了一些测试...效果很好,但我真的需要做一些自定义的事情。

我不希望图片被扫描或在媒体存储中可用,因此我想让我的应用程序扫描目录并创建缩略图并显示这些缩略图。

我发现很难找到任何高质量的例子来做到这一点。

谁能帮忙举个小例子。

这就是我想要做的。

  1. 图片存储在sdcard的一个目录下。
  2. 使用我的自定义图库,它将扫描此目录,但“不”使用媒体存储
  3. 我需要显示目录的内容,但作为缩略图,我想我需要先创建这个缩略图吗?
  4. 点击缩略图应该是我的自定义图库中的全屏图像。

我想我只是需要一点帮助来从目录中获取图片,因为没有存储在 int eh mediastore 中,所以我不能使用查询。另一件让我担心的事情是,我需要为这些图像中的每一个创建缩略图(动态??),因为显示图像但缩小尺寸我怀疑这对性能非常不利。

谁能伸出援手?

提前致谢

最佳答案

我刚才也是这么做的。您必须将图像所在的文件夹名称传递给 setBaseFolder。此方法依次调用 refresh(),它使用 FilenameFilter(未包含代码但很容易实现)获取所有名为 orig_... 的图像。从该文件夹中提取 .jpg 并将其保存在 mFileList 中。然后我们调用 notifyDataSetChanged(),这反过来会为每个单元格触发 getView()

现在,在 getView() 中,我们要么从缓存中获取缩略图位图(如果已经存在),否则我们创建一个灰色占位符并启动 ThumbnailBuilder 以分别创建缩略图从中获取位图。

我认为您必须稍微更改 ThumbnailBuilder,因为我创建了相当大的“缩略图”(500x500),因为我也需要调整大小的图像用于其他目的。另外,当我处理相机拍摄的照片时,那里有一些东西,根据 exif 信息旋转图像。但基本上,ThumbnailBuilder 只是检查是否已经存在缩略图(我的缩略图放置在同一个文件夹中,但前缀为 small_ 而不是 orig_ ) - 如果缩略图已经存在,我们将其作为 Bitmap 获取并完成,否则生成图像。最后,在 onPostExecute() 中将位图设置为 ImageView。

public class PhotoAdapter extends BaseAdapter {

private Context mContext;
private int mCellSize;
private File mFolder;
private File[] mFileList;
private Map<Object, Bitmap> mThumbnails = new HashMap<Object, Bitmap>();
private Set<Object> mCreatingTriggered = new HashSet<Object>(); // flag that creating already triggered

public PhotoAdapter(Context context, int cellSize) {
mContext = context;
mCellSize = cellSize;
}

@Override
public int getCount() {
if (mFolder == null) {
return 0; // don't do this
} else {
return mFileList.length;
}
}

@Override
public Object getItem(int position) {
return mFileList[position];
}

@Override
public long getItemId(int position) {
return position;
}

@Override
public View getView(int position, View convertView, ViewGroup parent) {
ImageView view = (ImageView)convertView;
if (view == null) {
view = new ImageView(mContext);
view.setLayoutParams(new GridView.LayoutParams(mCellSize, mCellSize));
view.setScaleType(ImageView.ScaleType.CENTER_CROP);
view.setPadding(8, 8, 8, 8);
view.setBackgroundColor(0xFFC6CCD3);
}
Object item = getItem(position);
Bitmap bm = mThumbnails.get(item);
if (bm == null) {
view.setImageBitmap(null);
if (!mCreatingTriggered.contains(item)) {
mCreatingTriggered.add(item);
new ThumbnailBuilder(view, (File)item).execute();
}
} else {
view.setImageBitmap(bm);
}
return view;
}

public void setBaseFolder(File baseFolder) {
if (baseFolder == null) return;
if (!baseFolder.equals(mFolder)) {
releaseThumbnails();
mFolder = baseFolder;
}
refresh();
}

public void refresh() {
if (mFolder == null) {
return;
}
mFileList = mFolder.listFiles(EtbApplication.origImageFilenameFilter);
if (mFileList == null) mFileList = new File[0];
notifyDataSetChanged();
}

public void releaseThumbnails() {
for (Bitmap bm : mThumbnails.values()) {
bm.recycle();
}
mThumbnails.clear();
}

// ------------------------------------------------------------------------------------ Asynchronous Thumbnail builder

private class ThumbnailBuilder extends AsyncTask<Void, Integer, Bitmap> {

private ImageView mView;
private File mFile;

public ThumbnailBuilder(ImageView view, File file) {
mView = view;
mFile = file;
}

@Override
protected Bitmap doInBackground(Void... params) {
Log.d("adapter", "make small image and thumbnail");
try {
return createThumbnail(mFile.getAbsolutePath());
} catch (Exception e) {
return null;
}
}

@Override
protected void onPostExecute(Bitmap result) {
if (result != null) {
mView.setImageBitmap(result);
mThumbnails.put(mFile, result);
} else {
mView.setImageResource(R.drawable.ic_launcher);
}
}

/**
* Creates Thumbnail (also rotates according to exif-info)
* @param file
* @return
* @throws IOException
*/
private Bitmap createThumbnail(String file) throws IOException {

File thumbnailFile = new File(file.replace("orig_", "small_"));

// If a small image version already exists, just load it and be done.
if (thumbnailFile.exists()) {
return BitmapFactory.decodeFile(thumbnailFile.getAbsolutePath());
}

// Decode image size
BitmapFactory.Options bounds = new BitmapFactory.Options();
bounds.inJustDecodeBounds = true;
BitmapFactory.decodeFile(file, bounds);

if ((bounds.outWidth == -1) || (bounds.outHeight == -1))
return null;

int w, h;

if (bounds.outWidth > bounds.outHeight) { // Querformat
w = 500;
h = 500 * bounds.outHeight / bounds.outWidth;
} else { // Hochformat
h = 500;
w = 500 * bounds.outWidth / bounds.outHeight;
}

BitmapFactory.Options opts = new BitmapFactory.Options();
opts.inSampleSize = 4; // resample -- kleiner aber noch nicht die 500 Pixel, die kommen dann unten
Bitmap resizedBitmap = BitmapFactory.decodeFile(file, opts);
resizedBitmap = Bitmap.createScaledBitmap(resizedBitmap, w, h, true);

ExifInterface exif = new ExifInterface(file);
String orientString = exif.getAttribute(ExifInterface.TAG_ORIENTATION);
int orientation = orientString != null ? Integer.parseInt(orientString) : ExifInterface.ORIENTATION_NORMAL;
int rotationAngle = 0;
if (orientation == ExifInterface.ORIENTATION_ROTATE_90) rotationAngle = 90;
if (orientation == ExifInterface.ORIENTATION_ROTATE_180) rotationAngle = 180;
if (orientation == ExifInterface.ORIENTATION_ROTATE_270) rotationAngle = 270;

Matrix matrix = new Matrix();
matrix.setRotate(rotationAngle, (float) resizedBitmap.getWidth() / 2, (float) resizedBitmap.getHeight() / 2);
Bitmap rotatedBitmap = Bitmap.createBitmap(resizedBitmap, 0, 0, w, h, matrix, true);
resizedBitmap.recycle();
ByteArrayOutputStream bytes = new ByteArrayOutputStream();
rotatedBitmap.compress(Bitmap.CompressFormat.JPEG, 90, bytes);

thumbnailFile.createNewFile();
FileOutputStream fo = new FileOutputStream(thumbnailFile);
fo.write(bytes.toByteArray());
fo.close();

//new File(file).delete(); // Originalbild löschen

return rotatedBitmap;
}
}
}

关于Android:扫描目录并显示图片(缩略图)(图片不存储在媒体存储中),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12190181/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com