summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTomaž Vajngerl <tomaz.vajngerl@collabora.co.uk>2024-04-18 14:54:52 +0900
committerTomaž Vajngerl <quikee@gmail.com>2024-04-25 07:17:51 +0200
commita938ed2be520426ce7949c4fd30a6e7e31d7c279 (patch)
treea5e1ec446830a11323cdfdfcccc05e29c97aa88a
parentb2b84dfa1d4f5da32f3335c59d618d385173a170 (diff)
annot: added Annotation impl. to svx, moved some thing from sd
This is an attempt to move the sd::Annotation to the common code in the svx module. This will need to be done in multiple steps so the first one is to introduce sdr::annotation::Annotation class in svx module, which is derived by sd::Annotation. Non-problematic functionality and members are also moved to the svx Annotation. Change-Id: Id20466b3780514ab63a9df8923b879098870ebb6 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/166492 Tested-by: Jenkins Reviewed-by: Tomaž Vajngerl <quikee@gmail.com>
-rw-r--r--include/svx/annotation/Annotation.hxx57
-rw-r--r--sd/inc/Annotation.hxx18
-rw-r--r--sd/source/core/annotations/Annotation.cxx8
-rw-r--r--svx/Library_svxcore.mk1
-rw-r--r--svx/source/annotation/Annotation.cxx18
5 files changed, 82 insertions, 20 deletions
diff --git a/include/svx/annotation/Annotation.hxx b/include/svx/annotation/Annotation.hxx
new file mode 100644
index 000000000000..13881a58d070
--- /dev/null
+++ b/include/svx/annotation/Annotation.hxx
@@ -0,0 +1,57 @@
+/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
+/*
+ * This file is part of the LibreOffice project.
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/.
+ */
+
+#pragma once
+
+#include <com/sun/star/geometry/RealPoint2D.hpp>
+#include <com/sun/star/geometry/RealSize2D.hpp>
+#include <com/sun/star/util/DateTime.hpp>
+
+#include <svx/svdpage.hxx>
+#include <svx/svxdllapi.h>
+
+namespace sdr::annotation
+{
+class SVXCORE_DLLPUBLIC Annotation
+{
+private:
+ static sal_uInt32 m_nLastId;
+ static sal_uInt32 nextID() { return m_nLastId++; }
+
+protected:
+ SdrPage* mpSdrPage;
+ sal_uInt32 m_nId;
+
+ css::geometry::RealPoint2D m_Position;
+ css::geometry::RealSize2D m_Size;
+ OUString m_Author;
+ OUString m_Initials;
+ css::util::DateTime m_DateTime;
+ bool m_bIsFreeText = false;
+
+public:
+ Annotation(SdrPage* pPage)
+ : mpSdrPage(pPage)
+ , m_nId(nextID())
+ {
+ }
+
+ SdrModel* GetModel()
+ {
+ return mpSdrPage != nullptr ? &mpSdrPage->getSdrModelFromSdrPage() : nullptr;
+ }
+
+ sal_uInt32 GetId() const { return m_nId; }
+};
+
+//typedef std::vector<rtl::Reference<Annotation>> AnnotationVector;
+
+} // namespace sdr::annotation
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/sd/inc/Annotation.hxx b/sd/inc/Annotation.hxx
index 965cbded3719..558271dbc04e 100644
--- a/sd/inc/Annotation.hxx
+++ b/sd/inc/Annotation.hxx
@@ -26,6 +26,7 @@
#include <com/sun/star/office/XAnnotation.hpp>
#include <comphelper/compbase.hxx>
#include <cppuhelper/propertysetmixin.hxx>
+#include <svx/annotation/Annotation.hxx>
#include "sdpage.hxx"
#include "textapi.hxx"
@@ -67,19 +68,16 @@ struct SD_DLLPUBLIC CustomAnnotationMarker
};
class SAL_DLLPUBLIC_RTTI Annotation final :
- public ::comphelper::WeakComponentImplHelper<css::office::XAnnotation>,
- public ::cppu::PropertySetMixin<css::office::XAnnotation>
+ public sdr::annotation::Annotation,
+ public ::comphelper::WeakComponentImplHelper<css::office::XAnnotation>,
+ public ::cppu::PropertySetMixin<css::office::XAnnotation>
{
public:
explicit Annotation( const css::uno::Reference<css::uno::XComponentContext>& context, SdPage* pPage );
Annotation(const Annotation&) = delete;
Annotation& operator=(const Annotation&) = delete;
- static sal_uInt32 m_nLastId;
-
SdPage* GetPage() const { return mpPage; }
- SdrModel* GetModel() { return (mpPage != nullptr) ? &mpPage->getSdrModelFromSdrPage() : nullptr; }
- sal_uInt32 GetId() const { return m_nId; }
// XInterface:
virtual css::uno::Any SAL_CALL queryInterface(css::uno::Type const & type) override;
@@ -141,17 +139,9 @@ private:
void createChangeUndoImpl(std::unique_lock<std::mutex>& g);
- sal_uInt32 m_nId;
SdPage* mpPage;
- css::geometry::RealPoint2D m_Position;
- css::geometry::RealSize2D m_Size;
- OUString m_Author;
- OUString m_Initials;
- css::util::DateTime m_DateTime;
rtl::Reference<TextApiObject> m_TextRange;
-
std::unique_ptr<CustomAnnotationMarker> m_pCustomAnnotationMarker;
- bool m_bIsFreeText;
};
}
diff --git a/sd/source/core/annotations/Annotation.cxx b/sd/source/core/annotations/Annotation.cxx
index fee7312bcca2..b3938002b87c 100644
--- a/sd/source/core/annotations/Annotation.cxx
+++ b/sd/source/core/annotations/Annotation.cxx
@@ -115,14 +115,10 @@ void createAnnotation(rtl::Reference<Annotation>& xAnnotation, SdPage* pPage )
pPage->addAnnotation(xAnnotation, -1);
}
-sal_uInt32 Annotation::m_nLastId = 1;
-
Annotation::Annotation(const uno::Reference<uno::XComponentContext>& context, SdPage* pPage)
- : ::cppu::PropertySetMixin<office::XAnnotation>(context, IMPLEMENTS_PROPERTY_SET,
- uno::Sequence<OUString>())
- , m_nId(m_nLastId++)
+ : sdr::annotation::Annotation(pPage)
+ , ::cppu::PropertySetMixin<office::XAnnotation>(context, IMPLEMENTS_PROPERTY_SET, uno::Sequence<OUString>())
, mpPage(pPage)
- , m_bIsFreeText(false)
{
}
diff --git a/svx/Library_svxcore.mk b/svx/Library_svxcore.mk
index 40fad5ea6b4f..1b1e6f5c2cf1 100644
--- a/svx/Library_svxcore.mk
+++ b/svx/Library_svxcore.mk
@@ -106,6 +106,7 @@ $(eval $(call gb_Library_use_system_darwin_frameworks,svxcore,\
endif
$(eval $(call gb_Library_add_exception_objects,svxcore,\
+ svx/source/annotation/Annotation \
svx/source/core/extedit \
svx/source/core/graphichelper \
svx/source/core/extendedprimitive2dxmldump \
diff --git a/svx/source/annotation/Annotation.cxx b/svx/source/annotation/Annotation.cxx
new file mode 100644
index 000000000000..df6e2175cef6
--- /dev/null
+++ b/svx/source/annotation/Annotation.cxx
@@ -0,0 +1,18 @@
+/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
+/*
+ * This file is part of the LibreOffice project.
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/.
+ */
+
+#include <svx/annotation/Annotation.hxx>
+
+namespace sdr::annotation
+{
+sal_uInt32 Annotation::m_nLastId = 1;
+
+} // namespace sdr::annotation
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */