Android Studio и Google Drive API (загрузка видео на Google Диск)

#java #android #google-drive-api

#java #Android #google-drive-api

Вопрос:

Я следовал руководству quickstart от Google, чтобы сделать снимок, а затем загрузить его на Google Диск пользователей.

Мой вопрос в том, как я могу адаптировать это к использованию видео и загрузке видео на Google Диск вместо изображения? Я уже знаю, как получить доступ к видео и записать его с помощью intents (и сохранить его во внешнем хранилище), но не знаю, как загрузить его впоследствии. Я предполагаю, что это будет почти то же самое, что и следующий код, но опять же не уверен.

Любая помощь будет оценена!

 /**
 * Android Drive Quickstart activity. This activity takes a photo and saves it
 * in Google Drive. The user is prompted with a pre-made dialog which allows
 * them to choose the file location.
 */
public class Main2Activity extends Activity implements ConnectionCallbacks,
        OnConnectionFailedListener {

    private static final String TAG = "drive-quickstart";
    private static final int REQUEST_CODE_CAPTURE_IMAGE = 1;
    private static final int REQUEST_CODE_CREATOR = 2;
    private static final int REQUEST_CODE_RESOLUTION = 3;

    private GoogleApiClient mGoogleApiClient;
    private Bitmap mBitmapToSave;


    /**
     * Create a new file and save it to Drive.
     */

    private void saveFileToDrive() {
        // Start by creating a new contents, and setting a callback.
        Log.i(TAG, "Creating new contents.");
        final Bitmap image = mBitmapToSave;
        Drive.DriveApi.newDriveContents(mGoogleApiClient)
                .setResultCallback(new ResultCallback<DriveContentsResult>() {

                    @Override
                    public void onResult(DriveContentsResult result) {
                        // If the operation was not successful, we cannot do anything
                        // and must
                        // fail.
                        if (!result.getStatus().isSuccess()) {
                            Log.i(TAG, "Failed to create new contents.");
                            return;
                        }
                        // Otherwise, we can write our data to the new contents.
                        Log.i(TAG, "New contents created.");
                        // Get an output stream for the contents.
                        OutputStream outputStream = result.getDriveContents().getOutputStream();
                        // Write the bitmap data from it.
                        ByteArrayOutputStream bitmapStream = new ByteArrayOutputStream();
                        image.compress(Bitmap.CompressFormat.PNG, 100, bitmapStream);
                        try {
                            outputStream.write(bitmapStream.toByteArray());
                        } catch (IOException e1) {
                            Log.i(TAG, "Unable to write file contents.");
                        }
                        // Create the initial metadata - MIME type and title.
                        // Note that the user will be able to change the title later.
                        MetadataChangeSet metadataChangeSet = new MetadataChangeSet.Builder()
                                .setMimeType("image/jpeg").setTitle("Android Photo.png").build();
                        // Create an intent for the file chooser, and start it.
                        IntentSender intentSender = Drive.DriveApi
                                .newCreateFileActivityBuilder()
                                .setInitialMetadata(metadataChangeSet)
                                .setInitialDriveContents(result.getDriveContents())
                                .build(mGoogleApiClient);
                        try {
                            startIntentSenderForResult(
                                    intentSender, REQUEST_CODE_CREATOR, null, 0, 0, 0);
                        } catch (SendIntentException e) {
                            Log.i(TAG, "Failed to launch file chooser.");
                        }
                    }
                });
    }

    @Override
    protected void onResume() {
        super.onResume();
        if (mGoogleApiClient == null) {
            // Create the API client and bind it to an instance variable.
            // We use this instance as the callback for connection and connection
            // failures.
            // Since no account name is passed, the user is prompted to choose.
            mGoogleApiClient = new GoogleApiClient.Builder(this)
                    .addApi(Drive.API)
                    .addScope(Drive.SCOPE_FILE)
                    .addConnectionCallbacks(this)
                    .addOnConnectionFailedListener(this)
                    .build();
        }
        // Connect the client. Once connected, the camera is launched.
        mGoogleApiClient.connect();
    }

    @Override
    protected void onPause() {
        if (mGoogleApiClient != null) {
            mGoogleApiClient.disconnect();
        }
        super.onPause();
    }

    @Override
    protected void onActivityResult(final int requestCode, final int resultCode, final Intent data) {
        switch (requestCode) {
            case REQUEST_CODE_CAPTURE_IMAGE:
                // Called after a photo has been taken.
                if (resultCode == Activity.RESULT_OK) {
                    // Store the image data as a bitmap for writing later.
                    mBitmapToSave = (Bitmap) data.getExtras().get("data");
                }
                break;
            case REQUEST_CODE_CREATOR:
                // Called after a file is saved to Drive.
                if (resultCode == RESULT_OK) {
                    Log.i(TAG, "Image successfully saved.");
                    mBitmapToSave = null;
                    // Just start the camera again for another photo.
                    startActivityForResult(new Intent(MediaStore.ACTION_IMAGE_CAPTURE),
                            REQUEST_CODE_CAPTURE_IMAGE);
                }
                break;
        }
    }

    @Override
    public void onConnectionFailed(ConnectionResult result) {
        // Called whenever the API client fails to connect.
        Log.i(TAG, "GoogleApiClient connection failed: "   result.toString());
        if (!result.hasResolution()) {
            // show the localized error dialog.
            GoogleApiAvailability.getInstance().getErrorDialog(this, result.getErrorCode(), 0).show();
            return;
        }
        // The failure has a resolution. Resolve it.
        // Called typically when the app is not yet authorized, and an
        // authorization
        // dialog is displayed to the user.
        try {
            result.startResolutionForResult(this, REQUEST_CODE_RESOLUTION);
        } catch (SendIntentException e) {
            Log.e(TAG, "Exception while starting resolution activity", e);
        }
    }

    @Override
    public void onConnected(Bundle connectionHint) {
        Log.i(TAG, "API client connected.");
        if (mBitmapToSave == null) {
            // This activity has no UI of its own. Just start the camera.
            startActivityForResult(new Intent(MediaStore.ACTION_IMAGE_CAPTURE),
                    REQUEST_CODE_CAPTURE_IMAGE);
            return;
        }
        saveFileToDrive();
    }

    @Override
    public void onConnectionSuspended(int cause) {
        Log.i(TAG, "GoogleApiClient connection suspended");
    }
}
  

Комментарии:

1. По какой-то причине это не удалось включить

Ответ №1:

Во фрагменте кода вы можете попытаться изменить mimeType на application/vnd.google-apps.video и Bitmap typecast на (допустим) byte[] . Я просто не уверен, поскольку это связано с возможными большими файлами, и на странице Android Drive API нет документации о загрузке видео.

Однако есть и другие способы подойти к этому. Я могу предложить вам использовать вызовы REST при загрузке файлов.

Для видео (которое обычно имеет большой размер файла) я бы посоветовал вам использовать возобновляемые загрузки. У него есть некоторые предварительные требования, которые вам нужно выполнить

Шаги по использованию возобновляемой загрузки включают:

  1. Запустите возобновляемый сеанс. Сделайте первоначальный запрос к URI загрузки, который включает метаданные, если таковые имеются.

  2. Сохраните URI возобновляемого сеанса. Сохраните URI сеанса, возвращенный в ответе на первоначальный запрос; вы будете использовать его для оставшихся запросов в этом сеансе.

  3. Загрузите файл. Отправьте медиафайл в URI возобновляемого сеанса.

Более подробную информацию можно найти в документации.

Счастливого кодирования!

Комментарии:

1. Спасибо за совет. Я изо всех сил пытаюсь разобраться в коде resuamble. Я программист-новичок, ха-ха. Когда я пытаюсь написать код и следовать инструкциям, он заполняется красными метками внизу. Некоторые из них необходимо импортировать. У некоторых есть несколько вариантов импорта. Немного сбивает с толку: я

2. Извините, но я просто понятия не имею, что делать вообще. Ха-ха, я, кажется, совсем растерялся. Так мало информации о загрузке чего-либо, и когда я, наконец, нахожу что-либо, это вообще не имеет никакого отношения к видео