Успешная загрузка с использованием Android Drive API, но файл был поврежден
Это код, который я использую для захвата видео в течение 7 секунд, а затем для автоматической загрузки видео на Google Drive с помощью Google Drive Android API. Проблема в том, что когда загрузка завершена, я не могу воспроизвести видео. Можно воспроизвести сохраненное видео на смартфоне, но не загруженное видео.
public class Video extends
AppCompatActivity implements
SurfaceHolder.Callback, GoogleApiClient.ConnectionCallbacks,
GoogleApiClient.OnConnectionFailedListener
{
public static File file;
public static GoogleApiClient mGoogleApiClient;
MediaRecorder recorder;
SurfaceHolder holder;
boolean recording = false;
FileOutputStream fileOut;
public static final String TAG = "SaveMe";
private Camera camera;
private final static int CONNECTION_FAILURE_RESOLUTION_REQUEST = 9000;
Calendar calendar = Calendar.getInstance();
final int hours = calendar.get(Calendar.HOUR_OF_DAY);
final int minutes = calendar.get(Calendar.MINUTE);
int seconds = calendar.get(Calendar.SECOND);
Date dateNow = new Date();
SimpleDateFormat dateformatJava = new SimpleDateFormat("dd-MM-yyyy");
final String date = dateformatJava.format(dateNow);
private static final String STATE_RESOLVING_ERROR = "resolving_error";
private static final int REQUEST_RESOLVE_ERROR = 1001;
private static final String DIALOG_ERROR = "dialog_error";
private boolean mResolvingError = false;
@Override
protected void onCreate(Bundle savedInstanceState) {
mResolvingError = savedInstanceState != null && savedInstanceState.getBoolean(STATE_RESOLVING_ERROR, false);
mGoogleApiClient = new GoogleApiClient.Builder(this)
.addApi(Drive.API)
.addScope(Drive.SCOPE_FILE)
.addConnectionCallbacks(this)
.addOnConnectionFailedListener(this)
.build();
requestWindowFeature(Window.FEATURE_NO_TITLE);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN);
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
recorder = new MediaRecorder();
initRecorder();
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_video);
SurfaceView cameraView = (SurfaceView) findViewById(R.id.CameraView);
holder = cameraView.getHolder();
holder.addCallback(this);
holder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu_video, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
private void initRecorder() {
File folder = new File(Environment.getExternalStorageDirectory() + "/SaveMe");
boolean success = true;
if (!folder.exists()) {
success = folder.mkdir();
}
File folder2 = new File(Environment.getExternalStorageDirectory() + "/SaveMe/" + date);
boolean success2 = true;
if (!folder2.exists()) {
success2 = folder2.mkdir();
}
int cameraId = -1;
int numberOfCameras = Camera.getNumberOfCameras();
for (int i = 0; i < numberOfCameras; i++) {
Camera.CameraInfo info = new Camera.CameraInfo();
Camera.getCameraInfo(i, info);
if (info.facing == Camera.CameraInfo.CAMERA_FACING_FRONT) {
Log.d("saveme", "Camera found");
cameraId = i;
break;
}
}
recorder.setAudioSource(MediaRecorder.AudioSource.DEFAULT);
recorder.setVideoSource(MediaRecorder.VideoSource.DEFAULT);
CamcorderProfile cpHigh = CamcorderProfile.get(CamcorderProfile.QUALITY_HIGH);
recorder.setProfile(cpHigh);
file = new java.io.File(Environment.getExternalStorageDirectory() + "/SaveMe/" + date + "/Video " + hours + " " + minutes + ".mp4");
recorder.setOutputFile(Environment.getExternalStorageDirectory() + "/SaveMe/" + date + "/Video " + hours + " " + minutes + ".mp4");
Log.i(TAG, "saved");
recorder.setMaxDuration(9000); // 5 seconds
recorder.setMaxFileSize(5000000); // Approximately 5 megabytes
Log.i(TAG, "Start counting");
new Timer().schedule(new TimerTask() {@Override
public void run() {
runOnUiThread(new Runnable() {@Override
public void run() {
Log.i(TAG, "Thread 7 sec");
saveFiletoDrive(file);
}
});
}
}, 9000);
}
private void saveFiletoDrive(final File file) {
Log.i(TAG, "Saving....");
Drive.DriveApi.newDriveContents(getGoogleApiClient()).setResultCallback(
new ResultCallback < DriveApi.DriveContentsResult > () {@Override
public void onResult(DriveApi.DriveContentsResult result) {
String mime = "video/mp4";
if (!result.getStatus().isSuccess()) {
Log.i(TAG, "Failed to create new contents.");
return;
}
Log.i(TAG, "Connection successful, creating new contents...");
OutputStream outputStream = result.getDriveContents().getOutputStream();
FileInputStream fis;
try {
fis = new FileInputStream(file.getPath());
ByteArrayOutputStream baos = new ByteArrayOutputStream();
byte[] buf = new byte[1024];
int n;
while ((n = fis.read(buf)) != -1)
baos.write(buf, 0, n);
outputStream.write(baos.toByteArray());
baos.flush();
outputStream.close();
outputStream = null;
fis.close();
fis = null;
} catch (FileNotFoundException e) {
Log.w(TAG, "FileNotFoundException: " + e.getMessage());
} catch (IOException e1) {
Log.w(TAG, "Unable to write file contents." + e1.getMessage());
}
String title = file.getName();
MetadataChangeSet metadataChangeSet = new MetadataChangeSet.Builder()
.setMimeType(mime).setTitle(title).build();
Drive.DriveApi.getRootFolder(getGoogleApiClient())
.createFile(getGoogleApiClient(), metadataChangeSet, result.getDriveContents())
.setResultCallback(fileCallback);
Log.i(TAG, "Creating new video on Drive (" + title + ")");
}
});
}
final public ResultCallback < DriveFolder.DriveFileResult > fileCallback = new
ResultCallback < DriveFolder.DriveFileResult > () {@Override
public void onResult(DriveFolder.DriveFileResult result) {
if (!result.getStatus().isSuccess()) {
Log.i(TAG, "Error while trying to create the file");
return;
}
Log.i(TAG, "Successfull !");
}
};
private void prepareRecorder() {
recorder.setPreviewDisplay(holder.getSurface());
try {
recorder.prepare();
} catch (IllegalStateException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
public void surfaceCreated(SurfaceHolder holder) {
File folder = new File(Environment.getExternalStorageDirectory() + "/SaveMe");
boolean success = true;
if (!folder.exists()) {
success = folder.mkdir();
}
File folder2 = new File(Environment.getExternalStorageDirectory() + "/SaveMe/" + date);
boolean success2 = true;
if (!folder2.exists()) {
success2 = folder2.mkdir();
}
prepareRecorder();
recorder.start();
}
public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {
}
public void surfaceDestroyed(SurfaceHolder holder) {
if (recording) {
recorder.stop();
recording = false;
}
recorder.release();
}
public static GoogleApiClient getGoogleApiClient() {
return mGoogleApiClient;
}
@Override
public void onConnected(Bundle bundle) {
Log.w(TAG, "Connected to google ");
}
@Override
public void onConnectionSuspended(int i) {
}
@Override
protected void onStart() {
super.onStart();
if (!mResolvingError) { // more about this later
mGoogleApiClient.connect();
}
}
@Override
protected void onResume() {
super.onResume();
mGoogleApiClient.connect();
}
@Override
protected void onPause() {
super.onPause();
recorder.release();
if (mGoogleApiClient.isConnected()) {
mGoogleApiClient.disconnect();
}
}
@Override
protected void onStop() {
recorder.release();
mGoogleApiClient.disconnect();
super.onStop();
}
@Override
public void onConnectionFailed(ConnectionResult connectionResult) {
Log.w(TAG, "failed to connected to google ");
if (connectionResult.hasResolution()) {
try {
connectionResult.startResolutionForResult(this, CONNECTION_FAILURE_RESOLUTION_REQUEST);
} catch (IntentSender.SendIntentException e) {
e.printStackTrace();
}
} else {
Log.i(TAG, "Location services connection failed with code " + connectionResult.getErrorCode());
}
}
private class MyAsyncTask extends AsyncTask < Void, Void, Void > {@Override
protected Void doInBackground(Void...params) {
Log.i(TAG, "exec");
saveFiletoDrive(file);
return null;
}@Override
protected void onPostExecute(Void result) {
}
}
}