For generate my code I modified the samples putted from google on gitHub.
All Goes ok and the video upload has no problem but now I need to put some annotations or a 'end screen' to my videos because I need to redirect users to my site after they have seen my 'video preview'.
So, the workflow is something like this:
1) The user inserts title and description from a jsp page.
2) When he clicks on the button the software take the credentials of the user stored in my db and then pass all the parameters to the method i posted below.
3) the class uploads the video to YouTube.
Now my question is: there is an easy way to 'attach' my links to the uploaded video?
I should use something like annotations, call-to-action or any kind of overlay message/button on the video area.
It doesn't matter if the overlay persists for all the video duration or it appears only at the end of the video.
I hope someone can help me! And i hope google will rewrites the documentation in a better way because i became crazy for implements YouTube's API.
This is a snippet of my source code:
public static void upload( String jsonString, String videoPath, String title , String description, String articleTags, HttpServletRequest request) {
// This OAuth 2.0 access scope allows an application to upload files
// to the authenticated user's YouTube channel, but doesn't allow
// other types of access.
List<String> scopes = Lists.newArrayList("https://www.googleapis.com/auth/youtube.upload");
try {
// Authorize the request.
JSONObject jsonObj = new JSONObject(jsonString);
GoogleCredential credential = new GoogleCredential.Builder()
.setClientSecrets(jsonObj.getString("client_id"), jsonObj.getString("client_secret"))
.setJsonFactory(Auth.JSON_FACTORY).setTransport(Auth.HTTP_TRANSPORT).build()
.setRefreshToken(jsonObj.getString("refresh_token")).setAccessToken(jsonObj.getString("access_token"));
// This object is used to make YouTube Data API requests.
youtube = new YouTube.Builder(Auth.HTTP_TRANSPORT, Auth.JSON_FACTORY, credential).setApplicationName("virtual-cms-video-upload").build();
System.out.println("Uploading: " + videoPath);
// Add extra information to the video before uploading.
Video videoObjectDefiningMetadata = new Video();
// Set the video to be publicly visible. This is the default
// setting. Other supporting settings are "unlisted" and "private."
VideoStatus status = new VideoStatus();
status.setPrivacyStatus("public");
videoObjectDefiningMetadata.setStatus(status);
// Most of the video's metadata is set on the VideoSnippet object.
VideoSnippet snippet = new VideoSnippet();
// This code uses a Calendar instance to create a unique name and
// description for test purposes so that you can easily upload
// multiple files. You should remove this code from your project
// and use your own standard names instead.
snippet.setTitle (title );
snippet.setDescription(description);
if( !articleTags.trim().equals("") ){
// Set the keyword tags that you want to associate with the video.
List<String> tags = new ArrayList<String>();
for(int i = 0; i < articleTags.split(",").length ; i++){
tags.add(articleTags);
}
snippet.setTags(tags);
// Add the completed snippet object to the video resource.
videoObjectDefiningMetadata.setSnippet(snippet);
}
//InputStreamContent mediaContent = new InputStreamContent(VIDEO_FILE_FORMAT,UploadYouTubeVideo.class.getClassLoader().getResourceAsStream(videoPath));
InputStreamContent mediaContent = new InputStreamContent(VIDEO_FILE_FORMAT,new java.io.FileInputStream(new File(videoPath)));
// Insert the video. The command sends three arguments. The first
// specifies which information the API request is setting and which
// information the API response should return. The second argument
// is the video resource that contains metadata about the new video.
// The third argument is the actual video content.
YouTube.Videos.Insert videoInsert = youtube.videos().insert("snippet,statistics,status", videoObjectDefiningMetadata, mediaContent);
// Set the upload type and add an event listener.
MediaHttpUploader uploader = videoInsert.getMediaHttpUploader();
// Indicate whether direct media upload is enabled. A value of
// "True" indicates that direct media upload is enabled and that
// the entire media content will be uploaded in a single request.
// A value of "False," which is the default, indicates that the
// request will use the resumable media upload protocol, which
// supports the ability to resume an upload operation after a
// network interruption or other transmission failure, saving
// time and bandwidth in the event of network failures.
uploader.setDirectUploadEnabled(false);
MediaHttpUploaderProgressListener progressListener = new MediaHttpUploaderProgressListener() {
public void progressChanged(MediaHttpUploader uploader) throws IOException {
switch (uploader.getUploadState()) {
case INITIATION_STARTED:
System.out.println("Initiation Started");
break;
case INITIATION_COMPLETE:
System.out.println("Initiation Completed");
break;
case MEDIA_IN_PROGRESS:
System.out.println("Upload in progress");
System.out.println("Upload percentage: " + uploader.getProgress());
break;
case MEDIA_COMPLETE:
System.out.println("Upload Completed!");
break;
case NOT_STARTED:
System.out.println("Upload Not Started!");
break;
}
}
};
uploader.setProgressListener(progressListener);
// Call the API and upload the video.
Video returnedVideo = videoInsert.execute();
// Print data about the newly inserted video from the API response.
System.out.println("\n================== Returned Video ==================\n");
System.out.println(" - Id : " + returnedVideo.getId() );
System.out.println(" - Title : " + returnedVideo.getSnippet().getTitle() );
System.out.println(" - Tags : " + returnedVideo.getSnippet().getTags() );
System.out.println(" - Privacy Status: " + returnedVideo.getStatus().getPrivacyStatus());
System.out.println(" - Video Count : " + returnedVideo.getStatistics().getViewCount());
} catch (Exception ex) {
System.err.println("Throwable: " + ex.getMessage());
ex.printStackTrace();
}
}
Unfortunately, it is not possible, nor will it ever be as far as i can tell.
Not being able to add annotations is an intended behaviour. See this link: https://issuetracker.google.com/issues/35166657 - Status: Won't Fix (Intended behavior)
Apparently the best alternative is InVideo Programming but i do not believe this is suitable for your purpose, unless it can be video specific.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With