2016-10-11 2 views
0

Я выполнил руководство по быстрому старту Google, чтобы сделать снимок, а затем загрузите его пользователям Google Диска.Android Studio и API Google Диска (загрузка видео на Google Диск)

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

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

/** 
* 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"); 
    } 
} 
+0

По какой-то причине это не может быть включено –

ответ

0

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

Есть и другие способы приблизиться к этому. Я могу предложить вам использовать вызовы REST в uploading files.

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

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

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

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

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

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

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

+0

Спасибо за отзыв. Я изо всех сил пытаюсь вычислить код для повторного использования. Я программист noob haha. Когда я пытаюсь написать код и следую инструкциям, он заполняется красными метками внизу. Некоторым нужно импортировать. У некоторых есть несколько вариантов импорта. Немного смущает: I –

+0

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

Смежные вопросы