// Copyright 2016 The Draco Authors. // // 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. // #include "compression/point_cloud/point_cloud_sequential_decoder.h" #include "compression/attributes/linear_sequencer.h" #include "compression/attributes/sequential_attribute_decoders_controller.h" namespace draco { bool PointCloudSequentialDecoder::DecodeGeometryData() { int32_t num_points; if (!buffer()->Decode(&num_points)) return false; point_cloud()->set_num_points(num_points); return true; } bool PointCloudSequentialDecoder::CreateAttributesDecoder( int32_t att_decoder_id) { // Always create the basic attribute decoder. SetAttributesDecoder( att_decoder_id, std::unique_ptr( new SequentialAttributeDecodersController( std::unique_ptr( new LinearSequencer(point_cloud()->num_points()))))); return true; } } // namespace draco