You can use Veo on Vertex AI to extend videos that you previously generated using Veo. You can extend videos using either the Google Cloud console or the Vertex AI API.
For information about writing effective text prompts for video generation, see the Veo prompt guide.
Before you begin
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
- 
    
    
      In the Google Cloud console, on the project selector page, select or create a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 
- 
  
  
    
      Enable the Vertex AI API. Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
- 
    
    
      In the Google Cloud console, on the project selector page, select or create a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 
- 
  
  
    
      Enable the Vertex AI API. Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
- 
    Set up authentication for your environment. Select the tab for how you plan to use the samples on this page: ConsoleWhen you use the Google Cloud console to access Google Cloud services and APIs, you don't need to set up authentication. RESTTo use the REST API samples on this page in a local development environment, you use the credentials you provide to the gcloud CLI. Install the Google Cloud CLI. After installation, initialize the Google Cloud CLI by running the following command: gcloud initIf you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity. For more information, see Authenticate for using REST in the Google Cloud authentication documentation. 
Extend a video
The following examples show how you can extend a Veo video:
  
  
  
    
  
 In the Google Cloud console, go to the Vertex AI > Media Studio
page. Click Video to open the Video Media Studio page. In the Settings pane, configure the following settings: Model: Select Veo 2  Aspect ratio: Choose either 16:9 or 9:16. Number of results: Adjust the slider or enter a value between 1
and 4. Video length: Select a length between 5 seconds and
8 seconds. Output directory: Click Browse to create or select a
Cloud Storage bucket to store output files. In the Write your prompt box, enter your text prompt that describes the
videos to generate. Click  Generate. Hover over the video you want to extend then click 
class="material-icons">auto_fix_high AI actions >
Extend video. In the Write your prompt box, enter your text prompt that describes the
videos to generate. Click  Generate. 
          To learn more, see the
          
          SDK reference documentation.
          
Set environment variables to use the Gen AI SDK with Vertex AI:
Console
  
  
  
  
veo-2.0-generate-001.Python
  
  
    
      Install
      pip install --upgrade google-genai
# Replace the `GOOGLE_CLOUD_PROJECT` and `GOOGLE_CLOUD_LOCATION` values
# with appropriate values for your project.
export GOOGLE_CLOUD_PROJECT=GOOGLE_CLOUD_PROJECT
export GOOGLE_CLOUD_LOCATION=global
export GOOGLE_GENAI_USE_VERTEXAI=True
REST
After you set up your environment, you can use REST to test a text prompt. The following sample sends a request to the publisher model endpoint.
For more information about the Veo API, see the Veo on Vertex AI API.
- Use the following command to send a video generation request. This request begins a long-running operation and stores output to a Cloud Storage bucket you specify. - Before using any of the request data, make the following replacements: - PROJECT_ID: Your Google Cloud project ID.
- TEXT_PROMPT: The text prompt used to guide video generation.
- PATH_TO_VIDEO: The Cloud Storage path to the Veo video that you're extending.
- 
    OUTPUT_STORAGE_URI: Optional: The Cloud Storage bucket to
    store the output videos. If not provided, video bytes are returned in the
    response. For example: gs://video-bucket/output/.
- RESPONSE_COUNT: The number of video files you want to generate. Accepted integer values: 1-4.
- DURATION: The length of video files that you want to generate. Accepted integer values are 5-8.
- 
    
Additional optional parameters Use the following optional variables depending on your use case. Add some or all of the following parameters in the "parameters": {}object."parameters": { "aspectRatio": "ASPECT_RATIO", "negativePrompt": "NEGATIVE_PROMPT", "personGeneration": "PERSON_SAFETY_SETTING", // "resolution": RESOLUTION, // Veo 3 models only "sampleCount": RESPONSE_COUNT, "seed": SEED_NUMBER }- 
    ASPECT_RATIO: Optional: A string value that describes the aspect ratio of the generated videos. You can use the following values:- "16:9"for landscape
- "9:16"for portrait
 The default value is "16:9"
- 
    NEGATIVE_PROMPT: Optional: A string value that describes content that you want to prevent the model from generating.
- 
    PERSON_SAFETY_SETTING: Optional: A string value that controls the safety setting for generating people or face generation. You can use the following values:- 
        "allow_adult": Only allow generation of adult people and faces.
- 
        "disallow": Doesn't generate people or faces.
 The default value is "allow_adult".
- 
        
- 
    RESOLUTION: Optional: A string value that controls the resolution of the generated video. Supported by Veo 3 models only. You can use the following values:- "720p"
- "1080p"
 The default value is "720p".
- 
    RESPONSE_COUNT: Optional. An integer value that describes the number of videos to generate. The accepted range of values is1-4.
- 
    SEED_NUMBER: Optional. An uint32 value that the model uses to generate deterministic videos. Specifying a seed number with your request without changing other parameters guides the model to produce the same videos. The accepted range of values is0-4294967295.
 
- 
    
 - HTTP method and URL: - POST https://us-central1-aiplatform.googleapis.com/v1/projects/PROJECT_ID/locations/us-central1/publishers/google/models/veo-2.0-generate-001:predictLongRunning - Request JSON body: - { "instances": [ { "prompt": "TEXT_PROMPT", "video": { "gcsUri": "PATH_TO_VIDEO", "mimeType": "video/mp4" } } ], "parameters": { "storageUri": "OUTPUT_STORAGE_URI", "sampleCount": RESPONSE_COUNT } }- To send your request, choose one of these options: This request returns a full operation name with a unique operation ID. Use this full operation name to poll that status of the video generation request.- curl- Save the request body in a file named - request.json, and execute the following command:- curl -X POST \ 
 -H "Authorization: Bearer $(gcloud auth print-access-token)" \
 -H "Content-Type: application/json; charset=utf-8" \
 -d @request.json \
 "https://us-central1-aiplatform.googleapis.com/v1/projects/PROJECT_ID/locations/us-central1/publishers/google/models/veo-2.0-generate-001:predictLongRunning"- PowerShell- Save the request body in a file named - request.json, and execute the following command:- $cred = gcloud auth print-access-token 
 $headers = @{ "Authorization" = "Bearer $cred" }
 Invoke-WebRequest `
 -Method POST `
 -Headers $headers `
 -ContentType: "application/json; charset=utf-8" `
 -InFile request.json `
 -Uri "https://us-central1-aiplatform.googleapis.com/v1/projects/PROJECT_ID/locations/us-central1/publishers/google/models/veo-2.0-generate-001:predictLongRunning" | Select-Object -Expand Content- { "name": "projects/PROJECT_ID/locations/us-central1/publishers/google/models/veo-2.0-generate-001/operations/a1b07c8e-7b5a-4aba-bb34-3e1ccb8afcc8" }
- Optional: Check the status of the video generation long-running operation. - Before using any of the request data, make the following replacements: - PROJECT_ID: Your Google Cloud project ID.
- MODEL_ID: The model ID to use.
- OPERATION_ID: The unique operation ID returned in the original generate video request.
 - HTTP method and URL: - POST https://us-central1-aiplatform.googleapis.com/v1/projects/PROJECT_ID/locations/us-central1/publishers/google/models/MODEL_ID:fetchPredictOperation - Request JSON body: - { "operationName": "projects/PROJECT_ID/locations/us-central1/publishers/google/models/MODEL_ID/operations/OPERATION_ID" }- To send your request, choose one of these options: This request returns information about the operation, including if the operation is still running or is done.- curl- Save the request body in a file named - request.json, and execute the following command:- curl -X POST \ 
 -H "Authorization: Bearer $(gcloud auth print-access-token)" \
 -H "Content-Type: application/json; charset=utf-8" \
 -d @request.json \
 "https://us-central1-aiplatform.googleapis.com/v1/projects/PROJECT_ID/locations/us-central1/publishers/google/models/MODEL_ID:fetchPredictOperation"- PowerShell- Save the request body in a file named - request.json, and execute the following command:- $cred = gcloud auth print-access-token 
 $headers = @{ "Authorization" = "Bearer $cred" }
 Invoke-WebRequest `
 -Method POST `
 -Headers $headers `
 -ContentType: "application/json; charset=utf-8" `
 -InFile request.json `
 -Uri "https://us-central1-aiplatform.googleapis.com/v1/projects/PROJECT_ID/locations/us-central1/publishers/google/models/MODEL_ID:fetchPredictOperation" | Select-Object -Expand Content
What's next
- Generate videos from text
- Learn more about prompts
- Understand responsible AI and usage guidelines for Veo on Vertex AI