1 ///
2 /// Copyright (c) 2012, Texas A&M University
3 /// All rights reserved.
4 ///
5 /// Redistribution and use in source and binary forms, with or without
6 /// modification, are permitted provided that the following conditions
7 /// are met:
8 ///
9 ///  * Redistributions of source code must retain the above copyright
10 ///    notice, this list of conditions and the following disclaimer.
11 ///  * Redistributions in binary form must reproduce the above
12 ///    copyright notice, this list of conditions and the following
13 ///    disclaimer in the documentation and/or other materials provided
14 ///    with the distribution.
15 ///  * Neither the name of Texas A&M University nor the names of its
16 ///    contributors may be used to endorse or promote products derived
17 ///    from this software without specific prior written permission.
18 ///
19 /// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 /// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21 /// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22 /// FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23 /// COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
24 /// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25 /// BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26 /// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
27 /// CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 /// LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29 /// ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30 /// POSSIBILITY OF SUCH DAMAGE.
31 ///
32 /// The following software was written as part of a collaboration with the
33 /// University of South Carolina, Interdisciplinary Mathematics Institute.
34 ///
35 
36 ///
37 /// @file   cutCommand.cpp
38 /// @details the implementation of the class CutCommand
39 /// @author  Yue Li and Matthew Hielsberg
40 
41 #include <pcl/apps/point_cloud_editor/cutCommand.h>
42 #include <pcl/apps/point_cloud_editor/copyBuffer.h>
43 #include <pcl/apps/point_cloud_editor/selection.h>
44 
CutCommand(CopyBufferPtr copy_buffer_ptr,SelectionPtr selection_ptr,const CloudPtr & cloud_ptr)45 CutCommand::CutCommand (CopyBufferPtr copy_buffer_ptr,
46                         SelectionPtr selection_ptr,
47                         const CloudPtr& cloud_ptr)
48   : selection_ptr_(std::move(selection_ptr)), cloud_ptr_(cloud_ptr),
49     copy_buffer_ptr_(std::move(copy_buffer_ptr)), cut_selection_(cloud_ptr)
50 {
51 }
52 
~CutCommand()53 CutCommand::~CutCommand ()
54 {
55 }
56 
57 void
execute()58 CutCommand::execute ()
59 {
60   if (!cloud_ptr_)
61     return;
62   if (selection_ptr_->empty())
63     return;
64 
65   // do the copy
66   copy_buffer_ptr_ -> set(cloud_ptr_, *selection_ptr_);
67 
68   // back up copied points for undo
69   cut_cloud_buffer_ = *copy_buffer_ptr_;
70   cut_selection_ = *selection_ptr_;
71 
72    // remove the copied points from the cloud.
73   cloud_ptr_ -> remove(cut_selection_);
74 
75   // The selection points to the incorrect points or may have indices out of
76   // bounds, so we must clear it.
77   selection_ptr_ -> clear();
78 
79   // notify the cloud that the selection has changed
80   cloud_ptr_ -> setSelection(selection_ptr_);
81 }
82 
83 void
undo()84 CutCommand::undo()
85 {
86   if (!cloud_ptr_)
87     return;
88   cloud_ptr_ -> restore(cut_cloud_buffer_, cut_selection_);
89 }
90