AsposeThreeDCloud-ThreeDCloudApi/lib/AsposeThreeDCloud/Object/HTMLSaveOption.pm
=begin comment
Aspose.3D Cloud API Reference
No description provided (generated by Swagger Codegen https://github.com/swagger-api/swagger-codegen)
OpenAPI spec version: 3.0
Generated by: https://github.com/swagger-api/swagger-codegen.git
=end comment
=cut
#
# NOTE: This class is auto generated by the swagger code generator program.
# Do not edit the class manually.
# Ref: https://github.com/swagger-api/swagger-codegen
#
package AsposeThreeDCloud::Object::HTMLSaveOption;
require 5.6.0;
use strict;
use warnings;
use utf8;
use JSON qw(decode_json);
use Data::Dumper;
use Module::Runtime qw(use_module);
use Log::Any qw($log);
use Date::Parse;
use DateTime;
use AsposeThreeDCloud::Object::SaveFormat;
use AsposeThreeDCloud::Object::SaveOptions;
use AsposeThreeDCloud::Object::Vector3;
use base ("Class::Accessor", "Class::Data::Inheritable");
#
#
#
# NOTE: This class is auto generated by the swagger code generator program. Do not edit the class manually.
# REF: https://github.com/swagger-api/swagger-codegen
#
=begin comment
Aspose.3D Cloud API Reference
No description provided (generated by Swagger Codegen https://github.com/swagger-api/swagger-codegen)
OpenAPI spec version: 3.0
Generated by: https://github.com/swagger-api/swagger-codegen.git
=end comment
=cut
#
# NOTE: This class is auto generated by the swagger code generator program.
# Do not edit the class manually.
# Ref: https://github.com/swagger-api/swagger-codegen
#
__PACKAGE__->mk_classdata('attribute_map' => {});
__PACKAGE__->mk_classdata('swagger_types' => {});
__PACKAGE__->mk_classdata('method_documentation' => {});
__PACKAGE__->mk_classdata('class_documentation' => {});
# new object
sub new {
my ($class, %args) = @_;
my $self = bless {}, $class;
foreach my $attribute (keys %{$class->attribute_map}) {
my $args_key = $class->attribute_map->{$attribute};
$self->$attribute( $args{ $args_key } );
}
return $self;
}
# return perl hash
sub to_hash {
return decode_json(JSON->new->convert_blessed->encode( shift ));
}
# used by JSON for serialization
sub TO_JSON {
my $self = shift;
my $_data = {};
foreach my $_key (keys %{$self->attribute_map}) {
if (defined $self->{$_key}) {
$_data->{$self->attribute_map->{$_key}} = $self->{$_key};
}
}
return $_data;
}
# from Perl hashref
sub from_hash {
my ($self, $hash) = @_;
# loop through attributes and use swagger_types to deserialize the data
while ( my ($_key, $_type) = each %{$self->swagger_types} ) {
my $_json_attribute = $self->attribute_map->{$_key};
if ($_type =~ /^array\[/i) { # array
my $_subclass = substr($_type, 6, -1);
my @_array = ();
foreach my $_element (@{$hash->{$_json_attribute}}) {
push @_array, $self->_deserialize($_subclass, $_element);
}
$self->{$_key} = \@_array;
} elsif (exists $hash->{$_json_attribute}) { #hash(model), primitive, datetime
$self->{$_key} = $self->_deserialize($_type, $hash->{$_json_attribute});
} else {
$log->debugf("Warning: %s (%s) does not exist in input hash\n", $_key, $_json_attribute);
}
}
return $self;
}
# deserialize non-array data
sub _deserialize {
my ($self, $type, $data) = @_;
$log->debugf("deserializing %s with %s",Dumper($data), $type);
if ($type eq 'DateTime') {
return DateTime->from_epoch(epoch => str2time($data));
} elsif ( grep( /^$type$/, ('int', 'double', 'string', 'boolean'))) {
return $data;
} else { # hash(model)
my $_instance = eval "AsposeThreeDCloud::Object::$type->new()";
return $_instance->from_hash($data);
}
}
__PACKAGE__->class_documentation({description => '',
class => 'HTMLSaveOption',
required => [], # TODO
} );
__PACKAGE__->method_documentation({
'save_format' => {
datatype => 'SaveFormat',
base_name => 'SaveFormat',
description => 'Gets or sets of the SaveFormat.',
format => '',
read_only => '',
},
'lookup_paths' => {
datatype => 'ARRAY[string]',
base_name => 'LookupPaths',
description => 'Some files like OBJ depends on external file, the lookup paths will allows Aspose.3D to look for external file to load',
format => '',
read_only => '',
},
'file_name' => {
datatype => 'string',
base_name => 'FileName',
description => 'The file name of the exporting/importing scene. This is optional, but useful when serialize external assets like OBJ's material.',
format => '',
read_only => '',
},
'file_format' => {
datatype => 'string',
base_name => 'FileFormat',
description => 'The file format like FBX,U3D,PDF ....',
format => '',
read_only => '',
},
'show_grid' => {
datatype => 'boolean',
base_name => 'ShowGrid',
description => ' Display a grid in the scene. Default value is true.',
format => '',
read_only => '',
},
'show_rulers' => {
datatype => 'boolean',
base_name => 'ShowRulers',
description => ' Display rulers of x/y/z axises in the scene to measure the model. Default value is false',
format => '',
read_only => '',
},
'show_ui' => {
datatype => 'boolean',
base_name => 'ShowUI',
description => 'Display a simple UI in the scene. Default value is true',
format => '',
read_only => '',
},
'orientation_box' => {
datatype => 'boolean',
base_name => 'OrientationBox',
description => 'Display a orientation box. Default value is true.',
format => '',
read_only => '',
},
'up_vector' => {
datatype => 'string',
base_name => 'UpVector',
description => 'Gets or sets the up vector, value can be \"x\"/\"y\"/\"z\", default value is \"y\".',
format => '',
read_only => '',
},
'far_plane' => {
datatype => 'double',
base_name => 'FarPlane',
description => 'Gets or sets the far plane of the camera, default value is 1000',
format => '',
read_only => '',
},
'near_plane' => {
datatype => 'double',
base_name => 'NearPlane',
description => 'Gets or sets the near plane of the camera, default value is 1',
format => '',
read_only => '',
},
'look_at' => {
datatype => 'Vector3',
base_name => 'LookAt',
description => 'Gets or sets the default look at position, default value is (0, 0, 0)',
format => '',
read_only => '',
},
'camera_position' => {
datatype => 'Vector3',
base_name => 'CameraPosition',
description => 'Gets or sets the initial position of the camera, default value is (10, 10, 10)',
format => '',
read_only => '',
},
'field_of_view' => {
datatype => 'double',
base_name => 'FieldOfView',
description => ' Gets or sets the field of the view, default value is 45, measured in degree',
format => '',
read_only => '',
},
});
__PACKAGE__->swagger_types( {
'save_format' => 'SaveFormat',
'lookup_paths' => 'ARRAY[string]',
'file_name' => 'string',
'file_format' => 'string',
'show_grid' => 'boolean',
'show_rulers' => 'boolean',
'show_ui' => 'boolean',
'orientation_box' => 'boolean',
'up_vector' => 'string',
'far_plane' => 'double',
'near_plane' => 'double',
'look_at' => 'Vector3',
'camera_position' => 'Vector3',
'field_of_view' => 'double'
} );
__PACKAGE__->attribute_map( {
'save_format' => 'SaveFormat',
'lookup_paths' => 'LookupPaths',
'file_name' => 'FileName',
'file_format' => 'FileFormat',
'show_grid' => 'ShowGrid',
'show_rulers' => 'ShowRulers',
'show_ui' => 'ShowUI',
'orientation_box' => 'OrientationBox',
'up_vector' => 'UpVector',
'far_plane' => 'FarPlane',
'near_plane' => 'NearPlane',
'look_at' => 'LookAt',
'camera_position' => 'CameraPosition',
'field_of_view' => 'FieldOfView'
} );
__PACKAGE__->mk_accessors(keys %{__PACKAGE__->attribute_map});
1;