2017-08-25 19:54:22 +00:00
|
|
|
# Copyright 2015 Google Inc.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
|
|
|
|
require 'date'
|
|
|
|
require 'google/apis/core/base_service'
|
|
|
|
require 'google/apis/core/json_representation'
|
|
|
|
require 'google/apis/core/hashable'
|
|
|
|
require 'google/apis/errors'
|
|
|
|
|
|
|
|
module Google
|
|
|
|
module Apis
|
|
|
|
module StreetviewpublishV1
|
|
|
|
|
|
|
|
# Request to delete multiple Photos.
|
|
|
|
class BatchDeletePhotosRequest
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Required. IDs of the Photos. For HTTP
|
|
|
|
# GET requests, the URL query parameter should be
|
|
|
|
# `photoIds=<id1>&photoIds=<id2>&...`.
|
|
|
|
# Corresponds to the JSON property `photoIds`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :photo_ids
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@photo_ids = args[:photo_ids] if args.key?(:photo_ids)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Response to batch delete of one or more
|
|
|
|
# Photos.
|
|
|
|
class BatchDeletePhotosResponse
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The status for the operation to delete a single
|
|
|
|
# Photo in the batch request.
|
|
|
|
# Corresponds to the JSON property `status`
|
|
|
|
# @return [Array<Google::Apis::StreetviewpublishV1::Status>]
|
|
|
|
attr_accessor :status
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@status = args[:status] if args.key?(:status)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Response to batch get of Photos.
|
|
|
|
class BatchGetPhotosResponse
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# List of results for each individual
|
|
|
|
# Photo requested, in the same order as
|
|
|
|
# the requests in
|
|
|
|
# BatchGetPhotos.
|
|
|
|
# Corresponds to the JSON property `results`
|
|
|
|
# @return [Array<Google::Apis::StreetviewpublishV1::PhotoResponse>]
|
|
|
|
attr_accessor :results
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@results = args[:results] if args.key?(:results)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Request to update the metadata of photos.
|
|
|
|
# Updating the pixels of photos is not supported.
|
|
|
|
class BatchUpdatePhotosRequest
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Required. List of
|
|
|
|
# UpdatePhotoRequests.
|
|
|
|
# Corresponds to the JSON property `updatePhotoRequests`
|
|
|
|
# @return [Array<Google::Apis::StreetviewpublishV1::UpdatePhotoRequest>]
|
|
|
|
attr_accessor :update_photo_requests
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@update_photo_requests = args[:update_photo_requests] if args.key?(:update_photo_requests)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Response to batch update of metadata of one or more
|
|
|
|
# Photos.
|
|
|
|
class BatchUpdatePhotosResponse
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# List of results for each individual
|
|
|
|
# Photo updated, in the same order as
|
|
|
|
# the request.
|
|
|
|
# Corresponds to the JSON property `results`
|
|
|
|
# @return [Array<Google::Apis::StreetviewpublishV1::PhotoResponse>]
|
|
|
|
attr_accessor :results
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@results = args[:results] if args.key?(:results)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A connection is the link from a source photo to a destination photo.
|
|
|
|
class Connection
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Identifier for a Photo.
|
|
|
|
# Corresponds to the JSON property `target`
|
|
|
|
# @return [Google::Apis::StreetviewpublishV1::PhotoId]
|
|
|
|
attr_accessor :target
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@target = args[:target] if args.key?(:target)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A generic empty message that you can re-use to avoid defining duplicated
|
|
|
|
# empty messages in your APIs. A typical example is to use it as the request
|
|
|
|
# or the response type of an API method. For instance:
|
|
|
|
# service Foo `
|
|
|
|
# rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty);
|
|
|
|
# `
|
|
|
|
# The JSON representation for `Empty` is empty JSON object ````.
|
|
|
|
class Empty
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# An object representing a latitude/longitude pair. This is expressed as a pair
|
|
|
|
# of doubles representing degrees latitude and degrees longitude. Unless
|
|
|
|
# specified otherwise, this must conform to the
|
|
|
|
# <a href="http://www.unoosa.org/pdf/icg/2012/template/WGS_84.pdf">WGS84
|
|
|
|
# standard</a>. Values must be within normalized ranges.
|
|
|
|
# Example of normalization code in Python:
|
|
|
|
# def NormalizeLongitude(longitude):
|
|
|
|
# """Wraps decimal degrees longitude to [-180.0, 180.0]."""
|
|
|
|
# q, r = divmod(longitude, 360.0)
|
|
|
|
# if r > 180.0 or (r == 180.0 and q <= -1.0):
|
|
|
|
# return r - 360.0
|
|
|
|
# return r
|
|
|
|
# def NormalizeLatLng(latitude, longitude):
|
|
|
|
# """Wraps decimal degrees latitude and longitude to
|
|
|
|
# [-90.0, 90.0] and [-180.0, 180.0], respectively."""
|
|
|
|
# r = latitude % 360.0
|
|
|
|
# if r <= 90.0:
|
|
|
|
# return r, NormalizeLongitude(longitude)
|
|
|
|
# elif r >= 270.0:
|
|
|
|
# return r - 360, NormalizeLongitude(longitude)
|
|
|
|
# else:
|
|
|
|
# return 180 - r, NormalizeLongitude(longitude + 180.0)
|
|
|
|
# assert 180.0 == NormalizeLongitude(180.0)
|
|
|
|
# assert -180.0 == NormalizeLongitude(-180.0)
|
|
|
|
# assert -179.0 == NormalizeLongitude(181.0)
|
|
|
|
# assert (0.0, 0.0) == NormalizeLatLng(360.0, 0.0)
|
|
|
|
# assert (0.0, 0.0) == NormalizeLatLng(-360.0, 0.0)
|
|
|
|
# assert (85.0, 180.0) == NormalizeLatLng(95.0, 0.0)
|
|
|
|
# assert (-85.0, -170.0) == NormalizeLatLng(-95.0, 10.0)
|
|
|
|
# assert (90.0, 10.0) == NormalizeLatLng(90.0, 10.0)
|
|
|
|
# assert (-90.0, -10.0) == NormalizeLatLng(-90.0, -10.0)
|
|
|
|
# assert (0.0, -170.0) == NormalizeLatLng(-180.0, 10.0)
|
|
|
|
# assert (0.0, -170.0) == NormalizeLatLng(180.0, 10.0)
|
|
|
|
# assert (-90.0, 10.0) == NormalizeLatLng(270.0, 10.0)
|
|
|
|
# assert (90.0, 10.0) == NormalizeLatLng(-270.0, 10.0)
|
|
|
|
class LatLng
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The latitude in degrees. It must be in the range [-90.0, +90.0].
|
|
|
|
# Corresponds to the JSON property `latitude`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :latitude
|
|
|
|
|
|
|
|
# The longitude in degrees. It must be in the range [-180.0, +180.0].
|
|
|
|
# Corresponds to the JSON property `longitude`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :longitude
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@latitude = args[:latitude] if args.key?(:latitude)
|
|
|
|
@longitude = args[:longitude] if args.key?(:longitude)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Level information containing level number and its corresponding name.
|
|
|
|
class Level
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Required. A name assigned to this Level, restricted to 3 characters.
|
|
|
|
# Consider how the elevator buttons would be labeled for this level if there
|
|
|
|
# was an elevator.
|
|
|
|
# Corresponds to the JSON property `name`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :name
|
|
|
|
|
|
|
|
# Floor number, used for ordering. 0 indicates the ground level, 1 indicates
|
|
|
|
# the first level above ground level, -1 indicates the first level under
|
|
|
|
# ground level. Non-integer values are OK.
|
|
|
|
# Corresponds to the JSON property `number`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :number
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@name = args[:name] if args.key?(:name)
|
|
|
|
@number = args[:number] if args.key?(:number)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Response to list all photos that belong to a user.
|
|
|
|
class ListPhotosResponse
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Token to retrieve the next page of results, or empty if there are no more
|
|
|
|
# results in the list.
|
|
|
|
# Corresponds to the JSON property `nextPageToken`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :next_page_token
|
|
|
|
|
|
|
|
# List of photos. The maximum number of items returned is based on the
|
|
|
|
# pageSize field
|
|
|
|
# in the request.
|
|
|
|
# Corresponds to the JSON property `photos`
|
|
|
|
# @return [Array<Google::Apis::StreetviewpublishV1::Photo>]
|
|
|
|
attr_accessor :photos
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
|
|
|
|
@photos = args[:photos] if args.key?(:photos)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Photo is used to store 360 photos along with photo metadata.
|
|
|
|
class Photo
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Absolute time when the photo was captured.
|
|
|
|
# When the photo has no exif timestamp, this is used to set a timestamp in
|
|
|
|
# the photo metadata.
|
|
|
|
# Corresponds to the JSON property `captureTime`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :capture_time
|
|
|
|
|
|
|
|
# Connections to other photos. A connection represents the link from this
|
|
|
|
# photo to another photo.
|
|
|
|
# Corresponds to the JSON property `connections`
|
|
|
|
# @return [Array<Google::Apis::StreetviewpublishV1::Connection>]
|
|
|
|
attr_accessor :connections
|
|
|
|
|
|
|
|
# Output only. The download URL for the photo bytes. This field is set only
|
|
|
|
# when
|
|
|
|
# GetPhotoRequest.view
|
|
|
|
# is set to
|
|
|
|
# PhotoView.INCLUDE_DOWNLOAD_URL.
|
|
|
|
# Corresponds to the JSON property `downloadUrl`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :download_url
|
|
|
|
|
|
|
|
# Identifier for a Photo.
|
|
|
|
# Corresponds to the JSON property `photoId`
|
|
|
|
# @return [Google::Apis::StreetviewpublishV1::PhotoId]
|
|
|
|
attr_accessor :photo_id
|
|
|
|
|
|
|
|
# Places where this photo belongs.
|
|
|
|
# Corresponds to the JSON property `places`
|
|
|
|
# @return [Array<Google::Apis::StreetviewpublishV1::Place>]
|
|
|
|
attr_accessor :places
|
|
|
|
|
|
|
|
# Raw pose measurement for an entity.
|
|
|
|
# Corresponds to the JSON property `pose`
|
|
|
|
# @return [Google::Apis::StreetviewpublishV1::Pose]
|
|
|
|
attr_accessor :pose
|
|
|
|
|
|
|
|
# Output only. The share link for the photo.
|
|
|
|
# Corresponds to the JSON property `shareLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :share_link
|
|
|
|
|
|
|
|
# Output only. The thumbnail URL for showing a preview of the given photo.
|
|
|
|
# Corresponds to the JSON property `thumbnailUrl`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :thumbnail_url
|
|
|
|
|
|
|
|
# Upload reference for media files.
|
|
|
|
# Corresponds to the JSON property `uploadReference`
|
|
|
|
# @return [Google::Apis::StreetviewpublishV1::UploadRef]
|
|
|
|
attr_accessor :upload_reference
|
|
|
|
|
|
|
|
# Output only. View count of the photo.
|
|
|
|
# Corresponds to the JSON property `viewCount`
|
|
|
|
# @return [Fixnum]
|
|
|
|
attr_accessor :view_count
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@capture_time = args[:capture_time] if args.key?(:capture_time)
|
|
|
|
@connections = args[:connections] if args.key?(:connections)
|
|
|
|
@download_url = args[:download_url] if args.key?(:download_url)
|
|
|
|
@photo_id = args[:photo_id] if args.key?(:photo_id)
|
|
|
|
@places = args[:places] if args.key?(:places)
|
|
|
|
@pose = args[:pose] if args.key?(:pose)
|
|
|
|
@share_link = args[:share_link] if args.key?(:share_link)
|
|
|
|
@thumbnail_url = args[:thumbnail_url] if args.key?(:thumbnail_url)
|
|
|
|
@upload_reference = args[:upload_reference] if args.key?(:upload_reference)
|
|
|
|
@view_count = args[:view_count] if args.key?(:view_count)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Identifier for a Photo.
|
|
|
|
class PhotoId
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Required. A unique identifier for a photo.
|
|
|
|
# Corresponds to the JSON property `id`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :id
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@id = args[:id] if args.key?(:id)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Response payload for a single
|
|
|
|
# Photo
|
|
|
|
# in batch operations including
|
|
|
|
# BatchGetPhotos
|
|
|
|
# and
|
|
|
|
# BatchUpdatePhotos.
|
|
|
|
class PhotoResponse
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Photo is used to store 360 photos along with photo metadata.
|
|
|
|
# Corresponds to the JSON property `photo`
|
|
|
|
# @return [Google::Apis::StreetviewpublishV1::Photo]
|
|
|
|
attr_accessor :photo
|
|
|
|
|
|
|
|
# The `Status` type defines a logical error model that is suitable for different
|
|
|
|
# programming environments, including REST APIs and RPC APIs. It is used by
|
|
|
|
# [gRPC](https://github.com/grpc). The error model is designed to be:
|
|
|
|
# - Simple to use and understand for most users
|
|
|
|
# - Flexible enough to meet unexpected needs
|
|
|
|
# # Overview
|
|
|
|
# The `Status` message contains three pieces of data: error code, error message,
|
|
|
|
# and error details. The error code should be an enum value of
|
|
|
|
# google.rpc.Code, but it may accept additional error codes if needed. The
|
|
|
|
# error message should be a developer-facing English message that helps
|
|
|
|
# developers *understand* and *resolve* the error. If a localized user-facing
|
|
|
|
# error message is needed, put the localized message in the error details or
|
|
|
|
# localize it in the client. The optional error details may contain arbitrary
|
|
|
|
# information about the error. There is a predefined set of error detail types
|
|
|
|
# in the package `google.rpc` that can be used for common error conditions.
|
|
|
|
# # Language mapping
|
|
|
|
# The `Status` message is the logical representation of the error model, but it
|
|
|
|
# is not necessarily the actual wire format. When the `Status` message is
|
|
|
|
# exposed in different client libraries and different wire protocols, it can be
|
|
|
|
# mapped differently. For example, it will likely be mapped to some exceptions
|
|
|
|
# in Java, but more likely mapped to some error codes in C.
|
|
|
|
# # Other uses
|
|
|
|
# The error model and the `Status` message can be used in a variety of
|
|
|
|
# environments, either with or without APIs, to provide a
|
|
|
|
# consistent developer experience across different environments.
|
|
|
|
# Example uses of this error model include:
|
|
|
|
# - Partial errors. If a service needs to return partial errors to the client,
|
|
|
|
# it may embed the `Status` in the normal response to indicate the partial
|
|
|
|
# errors.
|
|
|
|
# - Workflow errors. A typical workflow has multiple steps. Each step may
|
|
|
|
# have a `Status` message for error reporting.
|
|
|
|
# - Batch operations. If a client uses batch request and batch response, the
|
|
|
|
# `Status` message should be used directly inside batch response, one for
|
|
|
|
# each error sub-response.
|
|
|
|
# - Asynchronous operations. If an API call embeds asynchronous operation
|
|
|
|
# results in its response, the status of those operations should be
|
|
|
|
# represented directly using the `Status` message.
|
|
|
|
# - Logging. If some API errors are stored in logs, the message `Status` could
|
|
|
|
# be used directly after any stripping needed for security/privacy reasons.
|
|
|
|
# Corresponds to the JSON property `status`
|
|
|
|
# @return [Google::Apis::StreetviewpublishV1::Status]
|
|
|
|
attr_accessor :status
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@photo = args[:photo] if args.key?(:photo)
|
|
|
|
@status = args[:status] if args.key?(:status)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Place metadata for an entity.
|
|
|
|
class Place
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Required. Place identifier, as described in
|
|
|
|
# https://developers.google.com/places/place-id.
|
|
|
|
# Corresponds to the JSON property `placeId`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :place_id
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@place_id = args[:place_id] if args.key?(:place_id)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Raw pose measurement for an entity.
|
|
|
|
class Pose
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Altitude of the pose in meters above ground level (as defined by WGS84).
|
|
|
|
# NaN indicates an unmeasured quantity.
|
|
|
|
# Corresponds to the JSON property `altitude`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :altitude
|
|
|
|
|
|
|
|
# Compass heading, measured at the center of the photo in degrees clockwise
|
|
|
|
# from North. Value must be >=0 and <360.
|
|
|
|
# NaN indicates an unmeasured quantity.
|
|
|
|
# Corresponds to the JSON property `heading`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :heading
|
|
|
|
|
|
|
|
# An object representing a latitude/longitude pair. This is expressed as a pair
|
|
|
|
# of doubles representing degrees latitude and degrees longitude. Unless
|
|
|
|
# specified otherwise, this must conform to the
|
|
|
|
# <a href="http://www.unoosa.org/pdf/icg/2012/template/WGS_84.pdf">WGS84
|
|
|
|
# standard</a>. Values must be within normalized ranges.
|
|
|
|
# Example of normalization code in Python:
|
|
|
|
# def NormalizeLongitude(longitude):
|
|
|
|
# """Wraps decimal degrees longitude to [-180.0, 180.0]."""
|
|
|
|
# q, r = divmod(longitude, 360.0)
|
|
|
|
# if r > 180.0 or (r == 180.0 and q <= -1.0):
|
|
|
|
# return r - 360.0
|
|
|
|
# return r
|
|
|
|
# def NormalizeLatLng(latitude, longitude):
|
|
|
|
# """Wraps decimal degrees latitude and longitude to
|
|
|
|
# [-90.0, 90.0] and [-180.0, 180.0], respectively."""
|
|
|
|
# r = latitude % 360.0
|
|
|
|
# if r <= 90.0:
|
|
|
|
# return r, NormalizeLongitude(longitude)
|
|
|
|
# elif r >= 270.0:
|
|
|
|
# return r - 360, NormalizeLongitude(longitude)
|
|
|
|
# else:
|
|
|
|
# return 180 - r, NormalizeLongitude(longitude + 180.0)
|
|
|
|
# assert 180.0 == NormalizeLongitude(180.0)
|
|
|
|
# assert -180.0 == NormalizeLongitude(-180.0)
|
|
|
|
# assert -179.0 == NormalizeLongitude(181.0)
|
|
|
|
# assert (0.0, 0.0) == NormalizeLatLng(360.0, 0.0)
|
|
|
|
# assert (0.0, 0.0) == NormalizeLatLng(-360.0, 0.0)
|
|
|
|
# assert (85.0, 180.0) == NormalizeLatLng(95.0, 0.0)
|
|
|
|
# assert (-85.0, -170.0) == NormalizeLatLng(-95.0, 10.0)
|
|
|
|
# assert (90.0, 10.0) == NormalizeLatLng(90.0, 10.0)
|
|
|
|
# assert (-90.0, -10.0) == NormalizeLatLng(-90.0, -10.0)
|
|
|
|
# assert (0.0, -170.0) == NormalizeLatLng(-180.0, 10.0)
|
|
|
|
# assert (0.0, -170.0) == NormalizeLatLng(180.0, 10.0)
|
|
|
|
# assert (-90.0, 10.0) == NormalizeLatLng(270.0, 10.0)
|
|
|
|
# assert (90.0, 10.0) == NormalizeLatLng(-270.0, 10.0)
|
|
|
|
# Corresponds to the JSON property `latLngPair`
|
|
|
|
# @return [Google::Apis::StreetviewpublishV1::LatLng]
|
|
|
|
attr_accessor :lat_lng_pair
|
|
|
|
|
|
|
|
# Level information containing level number and its corresponding name.
|
|
|
|
# Corresponds to the JSON property `level`
|
|
|
|
# @return [Google::Apis::StreetviewpublishV1::Level]
|
|
|
|
attr_accessor :level
|
|
|
|
|
|
|
|
# Pitch, measured at the center of the photo in degrees. Value must be >=-90
|
|
|
|
# and <= 90. A value of -90 means looking directly down, and a value of 90
|
|
|
|
# means looking directly up.
|
|
|
|
# NaN indicates an unmeasured quantity.
|
|
|
|
# Corresponds to the JSON property `pitch`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :pitch
|
|
|
|
|
|
|
|
# Roll, measured in degrees. Value must be >= 0 and <360. A value of 0
|
|
|
|
# means level with the horizon.
|
|
|
|
# NaN indicates an unmeasured quantity.
|
|
|
|
# Corresponds to the JSON property `roll`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :roll
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@altitude = args[:altitude] if args.key?(:altitude)
|
|
|
|
@heading = args[:heading] if args.key?(:heading)
|
|
|
|
@lat_lng_pair = args[:lat_lng_pair] if args.key?(:lat_lng_pair)
|
|
|
|
@level = args[:level] if args.key?(:level)
|
|
|
|
@pitch = args[:pitch] if args.key?(:pitch)
|
|
|
|
@roll = args[:roll] if args.key?(:roll)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# The `Status` type defines a logical error model that is suitable for different
|
|
|
|
# programming environments, including REST APIs and RPC APIs. It is used by
|
|
|
|
# [gRPC](https://github.com/grpc). The error model is designed to be:
|
|
|
|
# - Simple to use and understand for most users
|
|
|
|
# - Flexible enough to meet unexpected needs
|
|
|
|
# # Overview
|
|
|
|
# The `Status` message contains three pieces of data: error code, error message,
|
|
|
|
# and error details. The error code should be an enum value of
|
|
|
|
# google.rpc.Code, but it may accept additional error codes if needed. The
|
|
|
|
# error message should be a developer-facing English message that helps
|
|
|
|
# developers *understand* and *resolve* the error. If a localized user-facing
|
|
|
|
# error message is needed, put the localized message in the error details or
|
|
|
|
# localize it in the client. The optional error details may contain arbitrary
|
|
|
|
# information about the error. There is a predefined set of error detail types
|
|
|
|
# in the package `google.rpc` that can be used for common error conditions.
|
|
|
|
# # Language mapping
|
|
|
|
# The `Status` message is the logical representation of the error model, but it
|
|
|
|
# is not necessarily the actual wire format. When the `Status` message is
|
|
|
|
# exposed in different client libraries and different wire protocols, it can be
|
|
|
|
# mapped differently. For example, it will likely be mapped to some exceptions
|
|
|
|
# in Java, but more likely mapped to some error codes in C.
|
|
|
|
# # Other uses
|
|
|
|
# The error model and the `Status` message can be used in a variety of
|
|
|
|
# environments, either with or without APIs, to provide a
|
|
|
|
# consistent developer experience across different environments.
|
|
|
|
# Example uses of this error model include:
|
|
|
|
# - Partial errors. If a service needs to return partial errors to the client,
|
|
|
|
# it may embed the `Status` in the normal response to indicate the partial
|
|
|
|
# errors.
|
|
|
|
# - Workflow errors. A typical workflow has multiple steps. Each step may
|
|
|
|
# have a `Status` message for error reporting.
|
|
|
|
# - Batch operations. If a client uses batch request and batch response, the
|
|
|
|
# `Status` message should be used directly inside batch response, one for
|
|
|
|
# each error sub-response.
|
|
|
|
# - Asynchronous operations. If an API call embeds asynchronous operation
|
|
|
|
# results in its response, the status of those operations should be
|
|
|
|
# represented directly using the `Status` message.
|
|
|
|
# - Logging. If some API errors are stored in logs, the message `Status` could
|
|
|
|
# be used directly after any stripping needed for security/privacy reasons.
|
|
|
|
class Status
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The status code, which should be an enum value of google.rpc.Code.
|
|
|
|
# Corresponds to the JSON property `code`
|
|
|
|
# @return [Fixnum]
|
|
|
|
attr_accessor :code
|
|
|
|
|
|
|
|
# A list of messages that carry the error details. There is a common set of
|
|
|
|
# message types for APIs to use.
|
|
|
|
# Corresponds to the JSON property `details`
|
|
|
|
# @return [Array<Hash<String,Object>>]
|
|
|
|
attr_accessor :details
|
|
|
|
|
|
|
|
# A developer-facing error message, which should be in English. Any
|
|
|
|
# user-facing error message should be localized and sent in the
|
|
|
|
# google.rpc.Status.details field, or localized by the client.
|
|
|
|
# Corresponds to the JSON property `message`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :message
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@code = args[:code] if args.key?(:code)
|
|
|
|
@details = args[:details] if args.key?(:details)
|
|
|
|
@message = args[:message] if args.key?(:message)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Request to update the metadata of a
|
|
|
|
# Photo. Updating the pixels of a photo
|
|
|
|
# is not supported.
|
|
|
|
class UpdatePhotoRequest
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Photo is used to store 360 photos along with photo metadata.
|
|
|
|
# Corresponds to the JSON property `photo`
|
|
|
|
# @return [Google::Apis::StreetviewpublishV1::Photo]
|
|
|
|
attr_accessor :photo
|
|
|
|
|
|
|
|
# Mask that identifies fields on the photo metadata to update.
|
2017-09-16 00:35:41 +00:00
|
|
|
# If not present, the old Photo
|
|
|
|
# metadata will be entirely replaced with the
|
|
|
|
# new Photo metadata in this request.
|
|
|
|
# The update fails if invalid fields are specified. Multiple fields can be
|
|
|
|
# specified in a comma-delimited list.
|
2017-08-25 19:54:22 +00:00
|
|
|
# The following fields are valid:
|
|
|
|
# * `pose.heading`
|
|
|
|
# * `pose.latLngPair`
|
|
|
|
# * `pose.pitch`
|
|
|
|
# * `pose.roll`
|
|
|
|
# * `pose.level`
|
|
|
|
# * `pose.altitude`
|
|
|
|
# * `connections`
|
|
|
|
# * `places`
|
|
|
|
# <aside class="note"><b>Note:</b> Repeated fields in
|
|
|
|
# updateMask
|
|
|
|
# mean the entire set of repeated values will be replaced with the new
|
|
|
|
# contents. For example, if
|
|
|
|
# updateMask
|
|
|
|
# contains `connections` and `UpdatePhotoRequest.photo.connections` is empty,
|
|
|
|
# all connections will be removed.</aside>
|
|
|
|
# Corresponds to the JSON property `updateMask`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :update_mask
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@photo = args[:photo] if args.key?(:photo)
|
|
|
|
@update_mask = args[:update_mask] if args.key?(:update_mask)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Upload reference for media files.
|
|
|
|
class UploadRef
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Required. An upload reference should be unique for each user. It follows
|
|
|
|
# the form:
|
|
|
|
# "https://streetviewpublish.googleapis.com/media/user/`account_id`/photo/`
|
|
|
|
# upload_reference`"
|
|
|
|
# Corresponds to the JSON property `uploadUrl`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :upload_url
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@upload_url = args[:upload_url] if args.key?(:upload_url)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|