Home | History | Annotate | Download | only in proto
      1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 // Protocol for video messages.
      6 
      7 syntax = "proto2";
      8 
      9 option optimize_for = LITE_RUNTIME;
     10 
     11 package remoting;
     12 
     13 message VideoPacketFormat {
     14   // Identifies how the image was encoded.
     15   enum Encoding {
     16     ENCODING_INVALID = -1;
     17     ENCODING_VERBATIM = 0;
     18     ENCODING_ZLIB = 1;
     19     ENCODING_VP8 = 2;
     20     ENCODING_VP9 = 3;
     21   };
     22 
     23   // The encoding used for this image update.
     24   optional Encoding encoding = 5 [default = ENCODING_INVALID];
     25 
     26   // Width and height of the whole screen.
     27   optional int32 screen_width = 6;
     28   optional int32 screen_height = 7;
     29 
     30   // Horizontal and vertical DPI of the screen. If either of these is zero or
     31   // unset, the corresponding DPI should be assumed to be 96 (Windows' default)
     32   optional int32 x_dpi = 8;
     33   optional int32 y_dpi = 9;
     34 }
     35 
     36 // TODO(hclam): Remove this message once we can obtain dirty rects from libvpx.
     37 message Rect {
     38   optional int32 x = 1;
     39   optional int32 y = 2;
     40   optional int32 width = 3;
     41   optional int32 height = 4;
     42 }
     43 
     44 message VideoPacket {
     45   // Deprecated. Must be set to 7 for backward compatibility.
     46   optional int32 deprecated_flags = 1 [default = 7];
     47 
     48   optional VideoPacketFormat format = 4;
     49 
     50   optional bytes data = 5;
     51 
     52   // List of rectangles updated by this frame.
     53   repeated Rect dirty_rects = 6;
     54 
     55   // Time in milliseconds spent in capturing this video frame.
     56   optional int32 capture_time_ms = 7;
     57 
     58   // Time in milliseconds spent in encoding this video frame.
     59   optional int32 encode_time_ms = 8;
     60 
     61   // The most recent sequence number received from the client on the event
     62   // channel.
     63   optional int64 client_sequence_number = 9;
     64 
     65   repeated Rect desktop_shape_rects = 10;
     66 
     67   // True when |desktop_shape_rects| should be used.
     68   optional bool use_desktop_shape = 11;
     69 }
     70