Fusion360-Addons/usr/autodesk/CPP/include/Fusion/Features/LoftSections.h
2021-10-31 19:11:02 +01:00

93 lines
3.4 KiB
C++

//////////////////////////////////////////////////////////////////////////////
//
// Copyright 2016 Autodesk, Inc. All rights reserved.
//
// Use of this software is subject to the terms of the Autodesk license
// agreement provided at the time of installation or download, or which
// otherwise accompanies this software.
//
//////////////////////////////////////////////////////////////////////////////
#pragma once
#include "../../Core/Base.h"
#include "../FusionTypeDefs.h"
// THIS CLASS WILL BE VISIBLE TO AN API CLIENT.
// THIS HEADER FILE WILL BE GENERATED FROM NIDL.
#include "../../Core/OSMacros.h"
#ifdef FUSIONXINTERFACE_EXPORTS
# ifdef __COMPILING_ADSK_FUSION_LOFTSECTIONS_CPP__
# define ADSK_FUSION_LOFTSECTIONS_API XI_EXPORT
# else
# define ADSK_FUSION_LOFTSECTIONS_API
# endif
#else
# define ADSK_FUSION_LOFTSECTIONS_API XI_IMPORT
#endif
namespace adsk { namespace fusion {
class LoftSection;
}}
namespace adsk { namespace fusion {
/// The set of two or more sections used to define the shape of the loft.
class LoftSections : public core::Base {
public:
/// The number of LoftSections in the collection.
size_t count() const;
/// Function that returns the specified LoftSection using an index into the collection. They are returned
/// in the same order that they are used in the loft. Their order can be modified using the reorder method
/// of the LoftSection object.
/// index : The index of the item within the collection to return. The first item in the collection has an index of 0.
/// Returns the specified item or null if an invalid index was specified.
core::Ptr<LoftSection> item(int index) const;
/// Adds a new section to the loft. The initial end condition is "Free". Additional methods on the
/// returned LoftSection can be used to further define the section.
/// If this LoftSections object is associated with a created feature, you need to position the timeline marker to immediately before this feature.
/// This can be accomplished using the following code: thisFeature.timelineObject.rollTo(True)
/// entity : Specifies the BRepFace, Profile, Path, SketchPoint, ConstructionPoint, or an ObjectCollection containing
/// a contiguous set of Profile objects that defines the section.
/// Returns the newly created LoftSection object.
core::Ptr<LoftSection> add(const core::Ptr<core::Base>& entity);
ADSK_FUSION_LOFTSECTIONS_API static const char* classType();
ADSK_FUSION_LOFTSECTIONS_API const char* objectType() const override;
ADSK_FUSION_LOFTSECTIONS_API void* queryInterface(const char* id) const override;
ADSK_FUSION_LOFTSECTIONS_API static const char* interfaceId() { return classType(); }
private:
// Raw interface
virtual size_t count_raw() const = 0;
virtual LoftSection* item_raw(int index) const = 0;
virtual LoftSection* add_raw(core::Base* entity) = 0;
};
// Inline wrappers
inline size_t LoftSections::count() const
{
size_t res = count_raw();
return res;
}
inline core::Ptr<LoftSection> LoftSections::item(int index) const
{
core::Ptr<LoftSection> res = item_raw(index);
return res;
}
inline core::Ptr<LoftSection> LoftSections::add(const core::Ptr<core::Base>& entity)
{
core::Ptr<LoftSection> res = add_raw(entity.get());
return res;
}
}// namespace fusion
}// namespace adsk
#undef ADSK_FUSION_LOFTSECTIONS_API