Android - Как загрузить большие ноты изображений (большие ноты http URL) в фоновом режиме - PullRequest
0 голосов
/ 08 ноября 2018

Я получаю список URL-адресов изображений с сервера, число которых приблизительно равно 400-500.Как я могу загрузить это изображение в фоновом режиме в локальную папку устройства?

ТАК, пока я запустил службу переднего плана, в которой я использую ExecutorService для запуска потока.Мой сервисный код ниже

public class SaveImageService extends Service {

    private Context context;
    public static final String NOTIFICATION_CHANNEL_ID = "10001";
    public SaveImageService() {
    }

    @Override
    public void onCreate() {
        super.onCreate();
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O)
            startMyOwnForeground();
        else
            startForeground(1, new Notification());
    }



    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        context = this;
        super.onStartCommand(intent, flags, startId);
        List<Callable<String>> saveDataThreads = new ArrayList<>();
        SaveTaskImage saveTaskImage = new SaveTaskImage(this);
        saveDataThreads.add(saveTaskImage);
        ExecutorService executor = Executors.newFixedThreadPool(saveDataThreads.size());
        try {
            List<Future<String>> aaa = executor.invokeAll(saveDataThreads);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        executor.shutdown();
        if (executor.isShutdown()) {
            stopForeground(true);
            stopSelf();
        }
        return START_STICKY;
    }

    @Override
    public IBinder onBind(Intent intent) {
        // TODO: Return the communication channel to the service.
        throw new UnsupportedOperationException("Not yet implemented");
    }

    @RequiresApi(api = Build.VERSION_CODES.O)
    private void startMyOwnForeground() {
        String NOTIFICATION_CHANNEL_ID = "com.example.simpleapp";
        String channelName = "My Background Service";
        NotificationChannel chan = new NotificationChannel(NOTIFICATION_CHANNEL_ID, channelName, NotificationManager.IMPORTANCE_NONE);
        chan.setLightColor(Color.BLUE);
        chan.setLockscreenVisibility(Notification.VISIBILITY_PRIVATE);
        NotificationManager manager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
        assert manager != null;
        manager.createNotificationChannel(chan);

        NotificationCompat.Builder notificationBuilder = new NotificationCompat.Builder(this, NOTIFICATION_CHANNEL_ID);
        Notification notification = notificationBuilder.setOngoing(true)
                .setSmallIcon(R.mipmap.talentify_logo_red)
                .setContentTitle("App is running in background")
                .setPriority(NotificationManager.IMPORTANCE_MIN)
                .setCategory(Notification.CATEGORY_SERVICE)
                .build();
        startForeground(2, notification);
    }
}

В потоке SaveTask я запускаю задачу синхронизации, как показано ниже

new SaveImageAsync ("file_path").executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR,url);

Ниже приведен мой код асинхронной задачи:

public class SaveImageAsync extends AsyncTask<String, Void, String> {
    private MediaSaver mediaSaver;

    public SaveImageAsync(MediaSaver mediaSaver){
        this.mediaSaver = mediaSaver;
    }
    @Override
    protected String doInBackground(String... params) {
        Bitmap bmp = null;
        try{
            System.out.println("Save image url --> "+params[0].replaceAll(" ", "%20"));
            URL url = new URL(params[0].replaceAll(" ", "%20"));
            InputStream fileInputStream = url.openStream();
            if(fileInputStream != null) {
                mediaSaver.save(fileInputStream);
                System.out.println("Saving  image --> ");
            }else{
                System.out.println("Not Saving  image --> ");

            }
        }catch (Exception e){
            e.printStackTrace();
        }
        return "";
    }

    @Override
    protected void onPostExecute(String string) {
    }
}

НоПри таком подходе я могу сохранить только 50 -60 изображений в фоновом режиме.Это не работает до конца.Что я должен сделать, пожалуйста, предложите

1 Ответ

0 голосов
/ 08 ноября 2018

Использовать ниже библиотеки -

implementation 'com.amitshekhar.android:android-networking:1.0.2'

Реализация этой библиотеки -

for (int j = 0; j < imageArrayList.size(); j++) {
        downloadImage(imageArrayList.getImagePath(j), imageArrayList.get(j),getImageName);
    }


 private void downloadImage(String imageURL, String imagename) {

    AndroidNetworking.download(imageURL, getCacheDir().getPath() + "/" + Constant.FOLDER_NAME + "/", imagename)
            .setPriority(Priority.HIGH)
            .build()
            .setDownloadProgressListener(new DownloadProgressListener() {
                @Override
                public void onProgress(long bytesDownloaded, long totalBytes) {
                    // do anything with progress
                }
            })
            .startDownload(new DownloadListener() {
                @Override
                public void onDownloadComplete() {

                    // do anything after completion


                }

                @Override
                public void onError(ANError error) {
                    // handle error

                }
            });

}

Вы также можете использовать Android DownloadManager API. Android: Как использовать класс менеджера загрузок?

...