summaryrefslogtreecommitdiff
path: root/sfx2/source/sidebar
diff options
context:
space:
mode:
Diffstat (limited to 'sfx2/source/sidebar')
-rw-r--r--sfx2/source/sidebar/TabBar.cxx4
-rw-r--r--sfx2/source/sidebar/Theme.cxx2
-rw-r--r--sfx2/source/sidebar/TitleBar.cxx4
-rw-r--r--sfx2/source/sidebar/Tools.cxx18
4 files changed, 18 insertions, 10 deletions
diff --git a/sfx2/source/sidebar/TabBar.cxx b/sfx2/source/sidebar/TabBar.cxx
index 4f49bd461364..7c8d98c7ff7d 100644
--- a/sfx2/source/sidebar/TabBar.cxx
+++ b/sfx2/source/sidebar/TabBar.cxx
@@ -150,7 +150,7 @@ void TabBar::UpdateButtonIcons()
if (xDeckDescriptor)
{
- aImage = GetItemImage(*xDeckDescriptor);
+ aImage = Image(GetItemImage(*xDeckDescriptor));
item.mpButton->SetModeImage(aImage);
}
}
@@ -292,7 +292,7 @@ VclPtr<RadioButton> TabBar::CreateTabItem(const DeckDescriptor& rDeckDescriptor)
return pItem;
}
-Image TabBar::GetItemImage(const DeckDescriptor& rDeckDescriptor) const
+css::uno::Reference<css::graphic::XGraphic> TabBar::GetItemImage(const DeckDescriptor& rDeckDescriptor) const
{
return Tools::GetImage(
rDeckDescriptor.msIconURL,
diff --git a/sfx2/source/sidebar/Theme.cxx b/sfx2/source/sidebar/Theme.cxx
index ce32455b0093..51a0debdc997 100644
--- a/sfx2/source/sidebar/Theme.cxx
+++ b/sfx2/source/sidebar/Theme.cxx
@@ -954,7 +954,7 @@ void Theme::ProcessNewValue (
OUString sURL;
if (rValue >>= sURL)
{
- maImages[nIndex] = Tools::GetImage(sURL, nullptr);
+ maImages[nIndex] = Image(Tools::GetImage(sURL, nullptr));
}
break;
}
diff --git a/sfx2/source/sidebar/TitleBar.cxx b/sfx2/source/sidebar/TitleBar.cxx
index c9dd0011b176..55aefc0f2725 100644
--- a/sfx2/source/sidebar/TitleBar.cxx
+++ b/sfx2/source/sidebar/TitleBar.cxx
@@ -60,9 +60,9 @@ void TitleBar::SetTitle(const OUString& rsTitle)
Invalidate();
}
-void TitleBar::SetIcon(const Image& rIcon)
+void TitleBar::SetIcon(const css::uno::Reference<css::graphic::XGraphic>& rIcon)
{
- maIcon = rIcon;
+ maIcon = Image(rIcon);
Invalidate();
}
diff --git a/sfx2/source/sidebar/Tools.cxx b/sfx2/source/sidebar/Tools.cxx
index 382914d8baba..ef9dce06cab6 100644
--- a/sfx2/source/sidebar/Tools.cxx
+++ b/sfx2/source/sidebar/Tools.cxx
@@ -21,6 +21,7 @@
#include <sfx2/sidebar/Theme.hxx>
+#include <comphelper/namedvaluecollection.hxx>
#include <comphelper/processfactory.hxx>
#include <vcl/commandinfoprovider.hxx>
#include <vcl/gradient.hxx>
@@ -29,13 +30,14 @@
#include <com/sun/star/frame/XFrame.hpp>
#include <com/sun/star/util/URLTransformer.hpp>
#include <com/sun/star/frame/ModuleManager.hpp>
+#include <com/sun/star/graphic/GraphicProvider.hpp>
using namespace css;
using namespace css::uno;
namespace sfx2::sidebar {
-Image Tools::GetImage (
+css::uno::Reference<css::graphic::XGraphic> Tools::GetImage(
const OUString& rsImageURL,
const OUString& rsHighContrastImageURL,
const Reference<frame::XFrame>& rxFrame)
@@ -46,19 +48,25 @@ Image Tools::GetImage (
return GetImage(rsImageURL, rxFrame);
}
-Image Tools::GetImage (
+css::uno::Reference<css::graphic::XGraphic> Tools::GetImage(
const OUString& rsURL,
const Reference<frame::XFrame>& rxFrame)
{
if (rsURL.getLength() > 0)
{
if (rsURL.startsWith(".uno:"))
- return vcl::CommandInfoProvider::GetImageForCommand(rsURL, rxFrame);
+ return vcl::CommandInfoProvider::GetXGraphicForCommand(rsURL, rxFrame);
else
- return Image(rsURL);
+ {
+ Reference<uno::XComponentContext> xContext(::comphelper::getProcessComponentContext());
+ Reference<graphic::XGraphicProvider> xProvider(graphic::GraphicProvider::create(xContext));
+ ::comphelper::NamedValueCollection aMediaProperties;
+ aMediaProperties.put("URL", rsURL);
+ return xProvider->queryGraphic(aMediaProperties.getPropertyValues());
+ }
}
- return Image();
+ return nullptr;
}
css::awt::Gradient Tools::VclToAwtGradient (const Gradient& rVclGradient)