2010-10-14 08:27:31 +02:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2012-10-02 14:13:40 +01:00
|
|
|
/*
|
|
|
|
* 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/.
|
|
|
|
*
|
|
|
|
* This file incorporates work covered by the following license notice:
|
|
|
|
*
|
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed
|
|
|
|
* with this work for additional information regarding copyright
|
|
|
|
* ownership. The ASF licenses this file to you 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 .
|
|
|
|
*/
|
2009-02-20 10:24:14 +00:00
|
|
|
|
|
|
|
|
|
|
|
#include <tools/stream.hxx>
|
|
|
|
#include <vcl/bitmap.hxx>
|
|
|
|
#include <vcl/window.hxx>
|
2010-10-18 12:28:33 +02:00
|
|
|
#include <sal/macros.h>
|
2009-02-20 10:24:14 +00:00
|
|
|
#include <com/sun/star/util/MeasureUnit.hpp>
|
|
|
|
#include <com/sun/star/awt/XBitmap.hpp>
|
|
|
|
#include <com/sun/star/awt/XWindow.hpp>
|
|
|
|
#include <com/sun/star/awt/XDevice.hpp>
|
|
|
|
#include <com/sun/star/awt/XPointer.hpp>
|
|
|
|
#include <com/sun/star/awt/SimpleFontMetric.hpp>
|
|
|
|
#include <com/sun/star/awt/FontDescriptor.hpp>
|
|
|
|
#include <com/sun/star/awt/XControlContainer.hpp>
|
|
|
|
#include <com/sun/star/awt/FontWeight.hpp>
|
|
|
|
#include <com/sun/star/awt/FontWidth.hpp>
|
CWS-TOOLING: integrate CWS dba32g
2009-09-09 07:53:55 +0200 oj r275964 : replace strlen with rtl_str_getLength
2009-09-07 20:59:10 +0200 fs r275913 : disable the CopyTableWizard test until issue 104869 is fixed
2009-09-07 12:17:31 +0200 oj r275885 : #i104810# remove de as lang
2009-09-05 22:26:21 +0200 fs r275857 : protect StateChanged against re-entrance
2009-09-05 22:25:52 +0200 fs r275856 : don't attempt to classify the parent of a form as control
2009-09-05 22:25:29 +0200 fs r275855 : protect against re-entrance
2009-09-05 00:11:40 +0200 fs r275835 : #i10000#
2009-09-04 23:25:50 +0200 fs r275834 : #i10000#
2009-09-04 23:23:47 +0200 fs r275833 : #i10000#
2009-09-04 21:49:37 +0200 fs r275830 : #i10000# correct wrong conflict resolution
2009-09-04 20:59:51 +0200 fs r275829 : CWS-TOOLING: rebase CWS dba32g to trunk@275801 (milestone: DEV300:m57)
2009-09-04 11:08:32 +0200 oj r275791 : #i104780# new version 1.2.0
2009-09-03 22:29:21 +0200 fs r275775 : OSL_TRACE doesn't need \n anymore
2009-09-03 08:33:21 +0200 fs r275743 : CWS-TOOLING: rebase CWS dba32g to trunk@275331 (milestone: DEV300:m56)
2009-09-02 13:48:12 +0200 fs r275708 : removed useless include
2009-09-02 13:45:43 +0200 fs r275707 : more since tags, which are used across offapi/udkapi
2009-09-02 13:23:04 +0200 fs r275705 : should *not* have the dtor, copy ctor, and assignment operator compiler-generated, else we run into trouble as soon as the compiler creates different versions of our singleton member's static data in different libraries
2009-09-02 12:32:45 +0200 fs r275704 : AutoIncrementIsPrimaryKey is a driver setting, not a data source setting
2009-09-02 11:42:49 +0200 fs r275701 : URL meta data are meta data which are valid for all connections of this type, not per-data-source properties. Settings them as data source properties is a hack.
2009-09-02 08:43:34 +0200 fs r275696 : 3.x.x is not a valid 'since' tag
2009-09-01 16:05:24 +0200 fs r275665 : #i104686# don't treat controls bound to read-only columns as required
2009-09-01 13:10:22 +0200 fs r275657 : #i104574# use PageUp/Down to scroll through the complete page
2009-09-01 07:04:48 +0200 oj r275641 : #i104104# correct line ends
2009-08-31 15:52:34 +0200 fs r275612 : #i104410#
2009-08-31 12:29:05 +0200 fs r275596 : #i104364#
2009-08-31 12:28:56 +0200 fs r275595 : #i104364#
2009-08-31 11:43:09 +0200 fs r275593 : #i104649# JavaDriverClassPath is also a known JDBC-bridge setting
2009-08-31 11:41:37 +0200 fs r275592 : #i104649#
2009-08-28 21:48:27 +0200 fs r275552 : during #i96862#: renamed the configuration data which controls availability of certain DBA-related UI
2009-08-28 21:48:17 +0200 fs r275551 : #i96862# do not show the 'Create a new database' option when a) no embedded/dBase driver is installed or b) the configuration requests to hide the option
2009-08-28 21:47:19 +0200 fs r275550 : during #i96862#: renamed the configuration data which controls availability of certain DBA-related UI
2009-08-28 21:46:41 +0200 fs r275549 : #i96862# renamed and extended the configuration data which controls availability of certain DBA-related UI
2009-08-28 15:10:19 +0200 fs r275535 : #i96862# if no embedded driver is installed, use dBase for creating new DBs. If no dBase driver is installed, too, do not offer the 'Create new database' option
2009-08-28 14:03:04 +0200 fs r275532 : #i104454# allow multiple fields to display the same column
2009-08-28 13:14:00 +0200 fs r275528 : #i104584# driver meta data do not belong into a data source's settings
2009-08-28 13:09:57 +0200 fs r275527 : properly chech the MySQL type buttons (else next/back in the wizard leads to state with two buttons checked)
2009-08-28 13:09:17 +0200 fs r275526 : #i104584# driver meta data do not belong into a data source's settings
2009-08-28 13:07:18 +0200 fs r275525 : BooleanComparisonMode is a property, or a feature - but not a driver meta data
2009-08-28 11:00:31 +0200 fs r275521 : #i104580#
2009-08-28 10:40:05 +0200 fs r275519 : #i104577# correct assertion: If the template node type is ANY, then any value type is allowed
2009-08-28 10:09:30 +0200 fs r275518 : #i104575# implement Named Pipe UI
2009-08-28 10:09:07 +0200 fs r275517 : pass the trigger-event to IWindowOperator::operateOn / work with VclWindowEvents, not VclSimpleEvents
2009-08-27 14:27:36 +0200 fs r275484 : ImplPosTabPage: respect mbEmptyViewMargin for WINDOWALIGN_LEFT
2009-08-27 13:43:56 +0200 fs r275480 : merging latest changes from CWS dba32f herein
2009-08-27 13:23:07 +0200 fs r275475 : #i103882#
2009-08-27 11:56:55 +0200 fs r275466 : #i104544# SetState: Do not call Update at the window which we just set text for. It should (sic\!) not be needed, but causes trouble
2009-08-27 11:55:34 +0200 fs r275465 : #i104544#
do not allow re-entrance for impl_ensureControl_nothrow
Actually, this is part of the fix only. I also removed the code which triggered this re-entrance (from
the grid control implementation), but to ensure it won't happen, again, I added some safety herein.
2009-08-27 10:14:11 +0200 fs r275459 : preparations for supporting a 'NamedPipe' parameter for the MySQL Connector/OOo
2009-08-27 10:13:21 +0200 fs r275458 : preparations for supporting a 'NamedPipe' setting for the MySQL Connector/OOo
2009-08-27 10:11:14 +0200 fs r275456 : outsourced the MySQLNative settings into a dedicated class, to not duplicate all the code in two tab page implementations
2009-08-26 14:18:13 +0200 fs r275422 : #i10000#
2009-08-26 13:26:36 +0200 fs r275419 : ignore output paths
2009-08-26 13:23:38 +0200 fs r275417 : support the LocalSocket property for the MySQL native driver
2009-08-26 13:17:05 +0200 fs r275416 : some re-factoring, to outsource the tab page for setting up the MySQLNative connection, into a dedicated class (needed later)
2009-08-26 13:15:15 +0200 fs r275415 : support a NoThousandSep property for NumericFormatters - I'm tired of correcting this at runtime, instead of controlling it in the resource
2009-08-26 11:45:08 +0200 fs r275410 : oops, 'flat' shouldn't have got lost
2009-08-26 09:38:57 +0200 fs r275398 : #i102631# when saving the document fails, ensure that the interaction handler really can handle/display the error
2009-08-26 09:37:05 +0200 fs r275397 : #i102631# don't let non-IO/RuntimeExceptions escape from DatabaseDocument::store*, wrap them into an IOException
2009-08-26 09:35:39 +0200 fs r275395 : let the default interaction handler implement XInteractionHandler2
2009-08-25 13:51:34 +0200 fs r275352 : #i102631# createTempFile: pass URL through FileHelper.getOOoCompatibleFileURL
2009-08-25 13:49:23 +0200 fs r275351 : #i102631# createTempFileURL: immediately delete the file implicitly created by createTempFile, we really only need the URL
2009-08-24 14:49:07 +0200 fs r275318 : #i10000#
2009-08-24 14:36:03 +0200 fs r275315 : properly terminate message with 0 character
2009-08-24 14:35:45 +0200 fs r275314 : trace method concepts in non-pro, if special flag is enabled
2009-08-24 14:24:17 +0200 fs r275312 : #i98973# filter some more events for grid control columns
2009-08-24 14:15:23 +0200 fs r275311 : #i98973# implement XComboBox for combo box cells
2009-08-24 13:39:24 +0200 fs r275308 : #i98973# do not display the 'actionPerformed' event for grid combo box columns
2009-08-24 12:52:03 +0200 fs r275303 : #i98973# implement XCheckBox and XButton for check box cells
2009-08-24 11:56:05 +0200 oj r275300 : #i104447# wrong default for orientation
2009-08-24 10:51:21 +0200 fs r275296 : in the script selector dialog, interpret a double click onto a function as OK
2009-08-24 10:50:56 +0200 fs r275295 : localize some to-be-displayed names, consolidate some code regarding form/control naming
2009-08-21 14:28:05 +0200 fs r275255 : #i98973# implement KeyListeners
2009-08-21 14:27:20 +0200 fs r275254 : #i98973# move the conversion VCL[Mouse|Key]Event->Awt[Mouse|Key]Event from vclxwindow.cxx to VCLUnoHelper
2009-08-21 14:08:50 +0200 fs r275248 : #i98973# implement Mouse- and MouseMotion-broadcasting
2009-08-21 13:31:08 +0200 fs r275244 : #i98973# implement text and change listeners at text cells
2009-08-21 12:47:38 +0200 fs r275234 : #i104399# some refactoring:
If the MySQL Connector/OOo is installed, it registers for the sdbc:mysqlc: protocol (now known as DST_MYSQL_NATIVE_DIRECT).
However, we do not want to display this in the UI, instead we display "MySQL" only, which collects DST_MYSQL_ODBC, DST_MYSQL_JDBC, and DST_MYSQL_NATIVE.
2009-08-21 12:45:18 +0200 fs r275232 : #i104399# also register for the sdbc:mysql:mysqlc protocol, decide at runtime (depending on the availability of sdbc:mysqlc:), whether it is really accepted. This prevents that the C/OOo extension needs to register *our* implementation name for the sdbc:mysql:mysqlc: protocol, which would be somewhat weird
2009-08-20 16:18:48 +0200 fs r275190 : merging the latest changes from CWS dba32f (which this CWS was created from)
2009-08-19 20:19:59 +0200 fs r275160 : add some spacing between the radios
2009-08-19 14:50:15 +0200 fs r275150 : #i98973# slightly refactoring the grid cell implementations, to prepare for proper events being fired. Implement focus events for the moment, more to come.
2009-08-19 10:53:38 +0200 fs r275142 : #i99936# initialize newly created models
2009-08-18 23:03:48 +0200 fs r275132 : merging latest changes from CWS dba32f
2009-08-18 15:14:08 +0200 fs r275110 : #i102819# SetColumnPos: SCROLL_CLIP is deadly here
2009-09-14 11:18:01 +00:00
|
|
|
#include <com/sun/star/awt/KeyModifier.hpp>
|
|
|
|
#include <com/sun/star/awt/MouseButton.hpp>
|
2009-02-20 10:24:14 +00:00
|
|
|
#include <com/sun/star/lang/XMultiServiceFactory.hpp>
|
|
|
|
#include <com/sun/star/embed/EmbedMapUnits.hpp>
|
|
|
|
|
|
|
|
#include <com/sun/star/graphic/XGraphic.hpp>
|
|
|
|
|
|
|
|
#include <toolkit/helper/vclunohelper.hxx>
|
|
|
|
#include <toolkit/helper/convert.hxx>
|
|
|
|
#include <toolkit/awt/vclxbitmap.hxx>
|
|
|
|
#include <toolkit/awt/vclxregion.hxx>
|
|
|
|
#include <toolkit/awt/vclxwindow.hxx>
|
|
|
|
#include <toolkit/awt/vclxgraphics.hxx>
|
|
|
|
#include <toolkit/awt/vclxpointer.hxx>
|
|
|
|
#include <toolkit/awt/vclxfont.hxx>
|
|
|
|
#include <toolkit/controls/unocontrolcontainer.hxx>
|
|
|
|
#include <toolkit/controls/unocontrolcontainermodel.hxx>
|
|
|
|
|
|
|
|
#include <vcl/graph.hxx>
|
|
|
|
#include <comphelper/processfactory.hxx>
|
|
|
|
|
2012-10-17 10:52:52 +02:00
|
|
|
#include <com/sun/star/awt/Toolkit.hpp>
|
2009-02-20 10:24:14 +00:00
|
|
|
#include <com/sun/star/awt/Size.hpp>
|
|
|
|
#include <com/sun/star/awt/Point.hpp>
|
|
|
|
|
CWS-TOOLING: integrate CWS dba32g
2009-09-09 07:53:55 +0200 oj r275964 : replace strlen with rtl_str_getLength
2009-09-07 20:59:10 +0200 fs r275913 : disable the CopyTableWizard test until issue 104869 is fixed
2009-09-07 12:17:31 +0200 oj r275885 : #i104810# remove de as lang
2009-09-05 22:26:21 +0200 fs r275857 : protect StateChanged against re-entrance
2009-09-05 22:25:52 +0200 fs r275856 : don't attempt to classify the parent of a form as control
2009-09-05 22:25:29 +0200 fs r275855 : protect against re-entrance
2009-09-05 00:11:40 +0200 fs r275835 : #i10000#
2009-09-04 23:25:50 +0200 fs r275834 : #i10000#
2009-09-04 23:23:47 +0200 fs r275833 : #i10000#
2009-09-04 21:49:37 +0200 fs r275830 : #i10000# correct wrong conflict resolution
2009-09-04 20:59:51 +0200 fs r275829 : CWS-TOOLING: rebase CWS dba32g to trunk@275801 (milestone: DEV300:m57)
2009-09-04 11:08:32 +0200 oj r275791 : #i104780# new version 1.2.0
2009-09-03 22:29:21 +0200 fs r275775 : OSL_TRACE doesn't need \n anymore
2009-09-03 08:33:21 +0200 fs r275743 : CWS-TOOLING: rebase CWS dba32g to trunk@275331 (milestone: DEV300:m56)
2009-09-02 13:48:12 +0200 fs r275708 : removed useless include
2009-09-02 13:45:43 +0200 fs r275707 : more since tags, which are used across offapi/udkapi
2009-09-02 13:23:04 +0200 fs r275705 : should *not* have the dtor, copy ctor, and assignment operator compiler-generated, else we run into trouble as soon as the compiler creates different versions of our singleton member's static data in different libraries
2009-09-02 12:32:45 +0200 fs r275704 : AutoIncrementIsPrimaryKey is a driver setting, not a data source setting
2009-09-02 11:42:49 +0200 fs r275701 : URL meta data are meta data which are valid for all connections of this type, not per-data-source properties. Settings them as data source properties is a hack.
2009-09-02 08:43:34 +0200 fs r275696 : 3.x.x is not a valid 'since' tag
2009-09-01 16:05:24 +0200 fs r275665 : #i104686# don't treat controls bound to read-only columns as required
2009-09-01 13:10:22 +0200 fs r275657 : #i104574# use PageUp/Down to scroll through the complete page
2009-09-01 07:04:48 +0200 oj r275641 : #i104104# correct line ends
2009-08-31 15:52:34 +0200 fs r275612 : #i104410#
2009-08-31 12:29:05 +0200 fs r275596 : #i104364#
2009-08-31 12:28:56 +0200 fs r275595 : #i104364#
2009-08-31 11:43:09 +0200 fs r275593 : #i104649# JavaDriverClassPath is also a known JDBC-bridge setting
2009-08-31 11:41:37 +0200 fs r275592 : #i104649#
2009-08-28 21:48:27 +0200 fs r275552 : during #i96862#: renamed the configuration data which controls availability of certain DBA-related UI
2009-08-28 21:48:17 +0200 fs r275551 : #i96862# do not show the 'Create a new database' option when a) no embedded/dBase driver is installed or b) the configuration requests to hide the option
2009-08-28 21:47:19 +0200 fs r275550 : during #i96862#: renamed the configuration data which controls availability of certain DBA-related UI
2009-08-28 21:46:41 +0200 fs r275549 : #i96862# renamed and extended the configuration data which controls availability of certain DBA-related UI
2009-08-28 15:10:19 +0200 fs r275535 : #i96862# if no embedded driver is installed, use dBase for creating new DBs. If no dBase driver is installed, too, do not offer the 'Create new database' option
2009-08-28 14:03:04 +0200 fs r275532 : #i104454# allow multiple fields to display the same column
2009-08-28 13:14:00 +0200 fs r275528 : #i104584# driver meta data do not belong into a data source's settings
2009-08-28 13:09:57 +0200 fs r275527 : properly chech the MySQL type buttons (else next/back in the wizard leads to state with two buttons checked)
2009-08-28 13:09:17 +0200 fs r275526 : #i104584# driver meta data do not belong into a data source's settings
2009-08-28 13:07:18 +0200 fs r275525 : BooleanComparisonMode is a property, or a feature - but not a driver meta data
2009-08-28 11:00:31 +0200 fs r275521 : #i104580#
2009-08-28 10:40:05 +0200 fs r275519 : #i104577# correct assertion: If the template node type is ANY, then any value type is allowed
2009-08-28 10:09:30 +0200 fs r275518 : #i104575# implement Named Pipe UI
2009-08-28 10:09:07 +0200 fs r275517 : pass the trigger-event to IWindowOperator::operateOn / work with VclWindowEvents, not VclSimpleEvents
2009-08-27 14:27:36 +0200 fs r275484 : ImplPosTabPage: respect mbEmptyViewMargin for WINDOWALIGN_LEFT
2009-08-27 13:43:56 +0200 fs r275480 : merging latest changes from CWS dba32f herein
2009-08-27 13:23:07 +0200 fs r275475 : #i103882#
2009-08-27 11:56:55 +0200 fs r275466 : #i104544# SetState: Do not call Update at the window which we just set text for. It should (sic\!) not be needed, but causes trouble
2009-08-27 11:55:34 +0200 fs r275465 : #i104544#
do not allow re-entrance for impl_ensureControl_nothrow
Actually, this is part of the fix only. I also removed the code which triggered this re-entrance (from
the grid control implementation), but to ensure it won't happen, again, I added some safety herein.
2009-08-27 10:14:11 +0200 fs r275459 : preparations for supporting a 'NamedPipe' parameter for the MySQL Connector/OOo
2009-08-27 10:13:21 +0200 fs r275458 : preparations for supporting a 'NamedPipe' setting for the MySQL Connector/OOo
2009-08-27 10:11:14 +0200 fs r275456 : outsourced the MySQLNative settings into a dedicated class, to not duplicate all the code in two tab page implementations
2009-08-26 14:18:13 +0200 fs r275422 : #i10000#
2009-08-26 13:26:36 +0200 fs r275419 : ignore output paths
2009-08-26 13:23:38 +0200 fs r275417 : support the LocalSocket property for the MySQL native driver
2009-08-26 13:17:05 +0200 fs r275416 : some re-factoring, to outsource the tab page for setting up the MySQLNative connection, into a dedicated class (needed later)
2009-08-26 13:15:15 +0200 fs r275415 : support a NoThousandSep property for NumericFormatters - I'm tired of correcting this at runtime, instead of controlling it in the resource
2009-08-26 11:45:08 +0200 fs r275410 : oops, 'flat' shouldn't have got lost
2009-08-26 09:38:57 +0200 fs r275398 : #i102631# when saving the document fails, ensure that the interaction handler really can handle/display the error
2009-08-26 09:37:05 +0200 fs r275397 : #i102631# don't let non-IO/RuntimeExceptions escape from DatabaseDocument::store*, wrap them into an IOException
2009-08-26 09:35:39 +0200 fs r275395 : let the default interaction handler implement XInteractionHandler2
2009-08-25 13:51:34 +0200 fs r275352 : #i102631# createTempFile: pass URL through FileHelper.getOOoCompatibleFileURL
2009-08-25 13:49:23 +0200 fs r275351 : #i102631# createTempFileURL: immediately delete the file implicitly created by createTempFile, we really only need the URL
2009-08-24 14:49:07 +0200 fs r275318 : #i10000#
2009-08-24 14:36:03 +0200 fs r275315 : properly terminate message with 0 character
2009-08-24 14:35:45 +0200 fs r275314 : trace method concepts in non-pro, if special flag is enabled
2009-08-24 14:24:17 +0200 fs r275312 : #i98973# filter some more events for grid control columns
2009-08-24 14:15:23 +0200 fs r275311 : #i98973# implement XComboBox for combo box cells
2009-08-24 13:39:24 +0200 fs r275308 : #i98973# do not display the 'actionPerformed' event for grid combo box columns
2009-08-24 12:52:03 +0200 fs r275303 : #i98973# implement XCheckBox and XButton for check box cells
2009-08-24 11:56:05 +0200 oj r275300 : #i104447# wrong default for orientation
2009-08-24 10:51:21 +0200 fs r275296 : in the script selector dialog, interpret a double click onto a function as OK
2009-08-24 10:50:56 +0200 fs r275295 : localize some to-be-displayed names, consolidate some code regarding form/control naming
2009-08-21 14:28:05 +0200 fs r275255 : #i98973# implement KeyListeners
2009-08-21 14:27:20 +0200 fs r275254 : #i98973# move the conversion VCL[Mouse|Key]Event->Awt[Mouse|Key]Event from vclxwindow.cxx to VCLUnoHelper
2009-08-21 14:08:50 +0200 fs r275248 : #i98973# implement Mouse- and MouseMotion-broadcasting
2009-08-21 13:31:08 +0200 fs r275244 : #i98973# implement text and change listeners at text cells
2009-08-21 12:47:38 +0200 fs r275234 : #i104399# some refactoring:
If the MySQL Connector/OOo is installed, it registers for the sdbc:mysqlc: protocol (now known as DST_MYSQL_NATIVE_DIRECT).
However, we do not want to display this in the UI, instead we display "MySQL" only, which collects DST_MYSQL_ODBC, DST_MYSQL_JDBC, and DST_MYSQL_NATIVE.
2009-08-21 12:45:18 +0200 fs r275232 : #i104399# also register for the sdbc:mysql:mysqlc protocol, decide at runtime (depending on the availability of sdbc:mysqlc:), whether it is really accepted. This prevents that the C/OOo extension needs to register *our* implementation name for the sdbc:mysql:mysqlc: protocol, which would be somewhat weird
2009-08-20 16:18:48 +0200 fs r275190 : merging the latest changes from CWS dba32f (which this CWS was created from)
2009-08-19 20:19:59 +0200 fs r275160 : add some spacing between the radios
2009-08-19 14:50:15 +0200 fs r275150 : #i98973# slightly refactoring the grid cell implementations, to prepare for proper events being fired. Implement focus events for the moment, more to come.
2009-08-19 10:53:38 +0200 fs r275142 : #i99936# initialize newly created models
2009-08-18 23:03:48 +0200 fs r275132 : merging latest changes from CWS dba32f
2009-08-18 15:14:08 +0200 fs r275110 : #i102819# SetColumnPos: SCROLL_CLIP is deadly here
2009-09-14 11:18:01 +00:00
|
|
|
using namespace ::com::sun::star;
|
|
|
|
|
2009-02-20 10:24:14 +00:00
|
|
|
// ----------------------------------------------------
|
|
|
|
// class VCLUnoHelper
|
|
|
|
// ----------------------------------------------------
|
|
|
|
|
2012-10-17 10:52:52 +02:00
|
|
|
uno::Reference< ::com::sun::star::awt::XToolkit> VCLUnoHelper::CreateToolkit()
|
2009-02-20 10:24:14 +00:00
|
|
|
{
|
2012-10-17 10:52:52 +02:00
|
|
|
uno::Reference< uno::XComponentContext > xContext = ::comphelper::getProcessComponentContext();
|
|
|
|
uno::Reference< awt::XToolkit> xToolkit( awt::Toolkit::create(xContext), uno::UNO_QUERY_THROW );
|
2009-02-20 10:24:14 +00:00
|
|
|
return xToolkit;
|
|
|
|
}
|
|
|
|
|
|
|
|
BitmapEx VCLUnoHelper::GetBitmap( const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XBitmap>& rxBitmap )
|
|
|
|
{
|
|
|
|
BitmapEx aBmp;
|
|
|
|
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::graphic::XGraphic > xGraphic( rxBitmap, ::com::sun::star::uno::UNO_QUERY );
|
|
|
|
if( xGraphic.is() )
|
|
|
|
{
|
|
|
|
Graphic aGraphic( xGraphic );
|
|
|
|
aBmp = aGraphic.GetBitmapEx();
|
|
|
|
}
|
|
|
|
else if ( rxBitmap.is() )
|
|
|
|
{
|
|
|
|
VCLXBitmap* pVCLBitmap = VCLXBitmap::GetImplementation( rxBitmap );
|
|
|
|
if ( pVCLBitmap )
|
|
|
|
aBmp = pVCLBitmap->GetBitmap();
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Bitmap aDIB, aMask;
|
|
|
|
{
|
|
|
|
::com::sun::star::uno::Sequence<sal_Int8> aBytes = rxBitmap->getDIB();
|
|
|
|
SvMemoryStream aMem( (char*) aBytes.getArray(), aBytes.getLength(), STREAM_READ );
|
|
|
|
aMem >> aDIB;
|
|
|
|
}
|
|
|
|
{
|
|
|
|
::com::sun::star::uno::Sequence<sal_Int8> aBytes = rxBitmap->getMaskDIB();
|
|
|
|
SvMemoryStream aMem( (char*) aBytes.getArray(), aBytes.getLength(), STREAM_READ );
|
|
|
|
aMem >> aMask;
|
|
|
|
}
|
|
|
|
aBmp = BitmapEx( aDIB, aMask );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return aBmp;
|
|
|
|
}
|
|
|
|
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::awt::XBitmap> VCLUnoHelper::CreateBitmap( const BitmapEx& rBitmap )
|
|
|
|
{
|
|
|
|
Graphic aGraphic( rBitmap );
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::awt::XBitmap> xBmp( aGraphic.GetXGraphic(), ::com::sun::star::uno::UNO_QUERY );
|
|
|
|
return xBmp;
|
|
|
|
}
|
|
|
|
|
|
|
|
Window* VCLUnoHelper::GetWindow( const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XWindow>& rxWindow )
|
|
|
|
{
|
|
|
|
VCLXWindow* pVCLXWindow = VCLXWindow::GetImplementation( rxWindow );
|
|
|
|
return pVCLXWindow ? pVCLXWindow->GetWindow() : NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
Window* VCLUnoHelper::GetWindow( const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XWindow2>& rxWindow )
|
|
|
|
{
|
|
|
|
VCLXWindow* pVCLXWindow = VCLXWindow::GetImplementation( rxWindow );
|
|
|
|
return pVCLXWindow ? pVCLXWindow->GetWindow() : NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
Window* VCLUnoHelper::GetWindow( const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XWindowPeer>& rxWindow )
|
|
|
|
{
|
|
|
|
VCLXWindow* pVCLXWindow = VCLXWindow::GetImplementation( rxWindow );
|
|
|
|
return pVCLXWindow ? pVCLXWindow->GetWindow() : NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
Region VCLUnoHelper::GetRegion( const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XRegion >& rxRegion )
|
|
|
|
{
|
|
|
|
Region aRegion;
|
|
|
|
VCLXRegion* pVCLRegion = VCLXRegion::GetImplementation( rxRegion );
|
|
|
|
if ( pVCLRegion )
|
|
|
|
aRegion = pVCLRegion->GetRegion();
|
|
|
|
else
|
|
|
|
{
|
|
|
|
::com::sun::star::uno::Sequence< ::com::sun::star::awt::Rectangle > aRects = rxRegion->getRectangles();
|
|
|
|
sal_Int32 nRects = aRects.getLength();
|
|
|
|
for ( sal_Int32 n = 0; n < nRects; n++ )
|
|
|
|
aRegion.Union( VCLRectangle( aRects.getArray()[n] ) );
|
|
|
|
}
|
|
|
|
return aRegion;
|
|
|
|
}
|
|
|
|
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::awt::XWindow> VCLUnoHelper::GetInterface( Window* pWindow )
|
|
|
|
{
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::awt::XWindow > xWin;
|
|
|
|
if ( pWindow )
|
|
|
|
{
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::awt::XWindowPeer> xPeer = pWindow->GetComponentInterface();
|
|
|
|
xWin = xWin.query( xPeer );
|
|
|
|
}
|
|
|
|
return xWin;
|
|
|
|
}
|
|
|
|
|
|
|
|
OutputDevice* VCLUnoHelper::GetOutputDevice( const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XDevice>& rxDevice )
|
|
|
|
{
|
|
|
|
OutputDevice* pOutDev = NULL;
|
|
|
|
VCLXDevice* pDev = VCLXDevice::GetImplementation( rxDevice );
|
|
|
|
if ( pDev )
|
|
|
|
pOutDev = pDev->GetOutputDevice();
|
|
|
|
return pOutDev;
|
|
|
|
}
|
|
|
|
|
|
|
|
OutputDevice* VCLUnoHelper::GetOutputDevice( const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XGraphics>& rxGraphics )
|
|
|
|
{
|
|
|
|
OutputDevice* pOutDev = NULL;
|
|
|
|
VCLXGraphics* pGrf = VCLXGraphics::GetImplementation( rxGraphics );
|
|
|
|
if ( pGrf )
|
|
|
|
pOutDev = pGrf->GetOutputDevice();
|
|
|
|
return pOutDev;
|
|
|
|
}
|
|
|
|
|
|
|
|
Polygon VCLUnoHelper::CreatePolygon( const ::com::sun::star::uno::Sequence< sal_Int32 >& DataX, const ::com::sun::star::uno::Sequence< sal_Int32 >& DataY )
|
|
|
|
{
|
|
|
|
sal_uInt32 nLen = DataX.getLength();
|
|
|
|
const sal_Int32* pDataX = DataX.getConstArray();
|
|
|
|
const sal_Int32* pDataY = DataY.getConstArray();
|
|
|
|
Polygon aPoly( (sal_uInt16) nLen );
|
|
|
|
for ( sal_uInt16 n = 0; n < nLen; n++ )
|
|
|
|
{
|
|
|
|
Point aPnt;
|
|
|
|
aPnt.X() = pDataX[n];
|
|
|
|
aPnt.Y() = pDataY[n];
|
|
|
|
aPoly[n] = aPnt;
|
|
|
|
}
|
|
|
|
return aPoly;
|
|
|
|
}
|
|
|
|
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::awt::XControlContainer> VCLUnoHelper::CreateControlContainer( Window* pWindow )
|
|
|
|
{
|
2010-12-07 09:51:12 +01:00
|
|
|
const uno::Reference< lang::XMultiServiceFactory > xFactory( ::comphelper::getProcessServiceFactory() );
|
2010-12-06 14:14:11 +01:00
|
|
|
UnoControlContainer* pContainer = new UnoControlContainer( xFactory, pWindow->GetComponentInterface( sal_True ) );
|
2009-02-20 10:24:14 +00:00
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::awt::XControlContainer > x = pContainer;
|
|
|
|
|
2010-12-06 14:14:11 +01:00
|
|
|
UnoControlModel* pContainerModel = new UnoControlContainerModel( xFactory );
|
2009-02-20 10:24:14 +00:00
|
|
|
pContainer->setModel( (::com::sun::star::awt::XControlModel*)pContainerModel );
|
|
|
|
|
|
|
|
return x;
|
|
|
|
}
|
|
|
|
|
|
|
|
float VCLUnoHelper::ConvertFontWidth( FontWidth eWidth )
|
|
|
|
{
|
|
|
|
if( eWidth == WIDTH_DONTKNOW )
|
|
|
|
return ::com::sun::star::awt::FontWidth::DONTKNOW;
|
|
|
|
else if( eWidth == WIDTH_ULTRA_CONDENSED )
|
|
|
|
return ::com::sun::star::awt::FontWidth::ULTRACONDENSED;
|
|
|
|
else if( eWidth == WIDTH_EXTRA_CONDENSED )
|
|
|
|
return ::com::sun::star::awt::FontWidth::EXTRACONDENSED;
|
|
|
|
else if( eWidth == WIDTH_CONDENSED )
|
|
|
|
return ::com::sun::star::awt::FontWidth::CONDENSED;
|
|
|
|
else if( eWidth == WIDTH_SEMI_CONDENSED )
|
|
|
|
return ::com::sun::star::awt::FontWidth::SEMICONDENSED;
|
|
|
|
else if( eWidth == WIDTH_NORMAL )
|
|
|
|
return ::com::sun::star::awt::FontWidth::NORMAL;
|
|
|
|
else if( eWidth == WIDTH_SEMI_EXPANDED )
|
|
|
|
return ::com::sun::star::awt::FontWidth::SEMIEXPANDED;
|
|
|
|
else if( eWidth == WIDTH_EXPANDED )
|
|
|
|
return ::com::sun::star::awt::FontWidth::EXPANDED;
|
|
|
|
else if( eWidth == WIDTH_EXTRA_EXPANDED )
|
|
|
|
return ::com::sun::star::awt::FontWidth::EXTRAEXPANDED;
|
|
|
|
else if( eWidth == WIDTH_ULTRA_EXPANDED )
|
|
|
|
return ::com::sun::star::awt::FontWidth::ULTRAEXPANDED;
|
|
|
|
|
2011-03-01 19:08:19 +01:00
|
|
|
OSL_FAIL( "Unknown FontWidth" );
|
2009-02-20 10:24:14 +00:00
|
|
|
return ::com::sun::star::awt::FontWidth::DONTKNOW;
|
|
|
|
}
|
|
|
|
|
|
|
|
FontWidth VCLUnoHelper::ConvertFontWidth( float f )
|
|
|
|
{
|
|
|
|
if( f <= ::com::sun::star::awt::FontWidth::DONTKNOW )
|
|
|
|
return WIDTH_DONTKNOW;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWidth::ULTRACONDENSED )
|
|
|
|
return WIDTH_ULTRA_CONDENSED;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWidth::EXTRACONDENSED )
|
|
|
|
return WIDTH_EXTRA_CONDENSED;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWidth::CONDENSED )
|
|
|
|
return WIDTH_CONDENSED;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWidth::SEMICONDENSED )
|
|
|
|
return WIDTH_SEMI_CONDENSED;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWidth::NORMAL )
|
|
|
|
return WIDTH_NORMAL;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWidth::SEMIEXPANDED )
|
|
|
|
return WIDTH_SEMI_EXPANDED;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWidth::EXPANDED )
|
|
|
|
return WIDTH_EXPANDED;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWidth::EXTRAEXPANDED )
|
|
|
|
return WIDTH_EXTRA_EXPANDED;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWidth::ULTRAEXPANDED )
|
|
|
|
return WIDTH_ULTRA_EXPANDED;
|
|
|
|
|
2011-03-01 19:08:19 +01:00
|
|
|
OSL_FAIL( "Unknown FontWidth" );
|
2009-02-20 10:24:14 +00:00
|
|
|
return WIDTH_DONTKNOW;
|
|
|
|
}
|
|
|
|
|
|
|
|
float VCLUnoHelper::ConvertFontWeight( FontWeight eWeight )
|
|
|
|
{
|
|
|
|
if( eWeight == WEIGHT_DONTKNOW )
|
|
|
|
return ::com::sun::star::awt::FontWeight::DONTKNOW;
|
|
|
|
else if( eWeight == WEIGHT_THIN )
|
|
|
|
return ::com::sun::star::awt::FontWeight::THIN;
|
|
|
|
else if( eWeight == WEIGHT_ULTRALIGHT )
|
|
|
|
return ::com::sun::star::awt::FontWeight::ULTRALIGHT;
|
|
|
|
else if( eWeight == WEIGHT_LIGHT )
|
|
|
|
return ::com::sun::star::awt::FontWeight::LIGHT;
|
|
|
|
else if( eWeight == WEIGHT_SEMILIGHT )
|
|
|
|
return ::com::sun::star::awt::FontWeight::SEMILIGHT;
|
|
|
|
else if( ( eWeight == WEIGHT_NORMAL ) || ( eWeight == WEIGHT_MEDIUM ) )
|
|
|
|
return ::com::sun::star::awt::FontWeight::NORMAL;
|
|
|
|
else if( eWeight == WEIGHT_SEMIBOLD )
|
|
|
|
return ::com::sun::star::awt::FontWeight::SEMIBOLD;
|
|
|
|
else if( eWeight == WEIGHT_BOLD )
|
|
|
|
return ::com::sun::star::awt::FontWeight::BOLD;
|
|
|
|
else if( eWeight == WEIGHT_ULTRABOLD )
|
|
|
|
return ::com::sun::star::awt::FontWeight::ULTRABOLD;
|
|
|
|
else if( eWeight == WEIGHT_BLACK )
|
|
|
|
return ::com::sun::star::awt::FontWeight::BLACK;
|
|
|
|
|
2011-03-01 19:08:19 +01:00
|
|
|
OSL_FAIL( "Unknown FontWeigth" );
|
2009-02-20 10:24:14 +00:00
|
|
|
return ::com::sun::star::awt::FontWeight::DONTKNOW;
|
|
|
|
}
|
|
|
|
|
|
|
|
FontWeight VCLUnoHelper::ConvertFontWeight( float f )
|
|
|
|
{
|
|
|
|
if( f <= ::com::sun::star::awt::FontWeight::DONTKNOW )
|
|
|
|
return WEIGHT_DONTKNOW;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWeight::THIN )
|
|
|
|
return WEIGHT_THIN;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWeight::ULTRALIGHT )
|
|
|
|
return WEIGHT_ULTRALIGHT;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWeight::LIGHT )
|
|
|
|
return WEIGHT_LIGHT;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWeight::SEMILIGHT )
|
|
|
|
return WEIGHT_SEMILIGHT;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWeight::NORMAL )
|
|
|
|
return WEIGHT_NORMAL;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWeight::SEMIBOLD )
|
|
|
|
return WEIGHT_SEMIBOLD;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWeight::BOLD )
|
|
|
|
return WEIGHT_BOLD;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWeight::ULTRABOLD )
|
|
|
|
return WEIGHT_ULTRABOLD;
|
|
|
|
else if( f <= ::com::sun::star::awt::FontWeight::BLACK )
|
|
|
|
return WEIGHT_BLACK;
|
|
|
|
|
2011-03-01 19:08:19 +01:00
|
|
|
OSL_FAIL( "Unknown FontWeigth" );
|
2009-02-20 10:24:14 +00:00
|
|
|
return WEIGHT_DONTKNOW;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
::com::sun::star::awt::FontDescriptor VCLUnoHelper::CreateFontDescriptor( const Font& rFont )
|
|
|
|
{
|
|
|
|
::com::sun::star::awt::FontDescriptor aFD;
|
|
|
|
aFD.Name = rFont.GetName();
|
|
|
|
aFD.StyleName = rFont.GetStyleName();
|
|
|
|
aFD.Height = (sal_Int16)rFont.GetSize().Height();
|
|
|
|
aFD.Width = (sal_Int16)rFont.GetSize().Width();
|
|
|
|
aFD.Family = sal::static_int_cast< sal_Int16 >(rFont.GetFamily());
|
|
|
|
aFD.CharSet = rFont.GetCharSet();
|
|
|
|
aFD.Pitch = sal::static_int_cast< sal_Int16 >(rFont.GetPitch());
|
|
|
|
aFD.CharacterWidth = VCLUnoHelper::ConvertFontWidth( rFont.GetWidthType() );
|
|
|
|
aFD.Weight= VCLUnoHelper::ConvertFontWeight( rFont.GetWeight() );
|
|
|
|
aFD.Slant = (::com::sun::star::awt::FontSlant)rFont.GetItalic();
|
|
|
|
aFD.Underline = sal::static_int_cast< sal_Int16 >(rFont.GetUnderline());
|
|
|
|
aFD.Strikeout = sal::static_int_cast< sal_Int16 >(rFont.GetStrikeout());
|
|
|
|
aFD.Orientation = rFont.GetOrientation();
|
|
|
|
aFD.Kerning = rFont.IsKerning();
|
|
|
|
aFD.WordLineMode = rFont.IsWordLineMode();
|
|
|
|
aFD.Type = 0; // ??? => Nur an Metric...
|
|
|
|
return aFD;
|
|
|
|
}
|
|
|
|
|
|
|
|
Font VCLUnoHelper::CreateFont( const ::com::sun::star::awt::FontDescriptor& rDescr, const Font& rInitFont )
|
|
|
|
{
|
|
|
|
Font aFont( rInitFont );
|
2012-01-16 15:46:57 -02:00
|
|
|
if ( !rDescr.Name.isEmpty() )
|
2009-02-20 10:24:14 +00:00
|
|
|
aFont.SetName( rDescr.Name );
|
2012-01-16 15:46:57 -02:00
|
|
|
if ( !rDescr.StyleName.isEmpty() )
|
2009-02-20 10:24:14 +00:00
|
|
|
aFont.SetStyleName( rDescr.StyleName );
|
|
|
|
if ( rDescr.Height )
|
|
|
|
aFont.SetSize( Size( rDescr.Width, rDescr.Height ) );
|
|
|
|
if ( (FontFamily)rDescr.Family != FAMILY_DONTKNOW )
|
|
|
|
aFont.SetFamily( (FontFamily)rDescr.Family );
|
|
|
|
if ( (CharSet)rDescr.CharSet != RTL_TEXTENCODING_DONTKNOW )
|
|
|
|
aFont.SetCharSet( (CharSet)rDescr.CharSet );
|
|
|
|
if ( (FontPitch)rDescr.Pitch != PITCH_DONTKNOW )
|
|
|
|
aFont.SetPitch( (FontPitch)rDescr.Pitch );
|
|
|
|
if ( rDescr.CharacterWidth )
|
|
|
|
aFont.SetWidthType( VCLUnoHelper::ConvertFontWidth( rDescr.CharacterWidth ) );
|
|
|
|
if ( rDescr.Weight )
|
|
|
|
aFont.SetWeight( VCLUnoHelper::ConvertFontWeight( rDescr.Weight ) );
|
|
|
|
if ( (FontItalic)rDescr.Slant != ITALIC_DONTKNOW )
|
|
|
|
aFont.SetItalic( (FontItalic)rDescr.Slant );
|
|
|
|
if ( (FontUnderline)rDescr.Underline != UNDERLINE_DONTKNOW )
|
|
|
|
aFont.SetUnderline( (FontUnderline)rDescr.Underline );
|
|
|
|
if ( (FontStrikeout)rDescr.Strikeout != STRIKEOUT_DONTKNOW )
|
|
|
|
aFont.SetStrikeout( (FontStrikeout)rDescr.Strikeout );
|
|
|
|
|
|
|
|
// Kein DONTKNOW
|
|
|
|
aFont.SetOrientation( (short)rDescr.Orientation );
|
|
|
|
aFont.SetKerning( rDescr.Kerning );
|
|
|
|
aFont.SetWordLineMode( rDescr.WordLineMode );
|
|
|
|
|
|
|
|
return aFont;
|
|
|
|
}
|
|
|
|
|
|
|
|
Font VCLUnoHelper::CreateFont( const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XFont >& rxFont )
|
|
|
|
{
|
|
|
|
Font aFont;
|
|
|
|
VCLXFont* pVCLXFont = VCLXFont::GetImplementation( rxFont );
|
|
|
|
if ( pVCLXFont )
|
|
|
|
aFont = pVCLXFont->GetFont();
|
|
|
|
return aFont;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
::com::sun::star::awt::SimpleFontMetric VCLUnoHelper::CreateFontMetric( const FontMetric& rFontMetric )
|
|
|
|
{
|
|
|
|
::com::sun::star::awt::SimpleFontMetric aFM;
|
|
|
|
aFM.Ascent = (sal_Int16)rFontMetric.GetAscent();
|
|
|
|
aFM.Descent = (sal_Int16)rFontMetric.GetDescent();
|
|
|
|
aFM.Leading = (sal_Int16)rFontMetric.GetIntLeading();
|
|
|
|
aFM.Slant = (sal_Int16)rFontMetric.GetSlant();
|
|
|
|
aFM.FirstChar = 0x0020;
|
|
|
|
aFM.LastChar = 0xFFFD;
|
|
|
|
return aFM;
|
|
|
|
}
|
|
|
|
|
|
|
|
sal_Bool VCLUnoHelper::IsZero( ::com::sun::star::awt::Rectangle rRect )
|
|
|
|
{
|
|
|
|
return ( !rRect.X && !rRect.Y && !rRect.Width && !rRect.Height );
|
|
|
|
}
|
|
|
|
|
|
|
|
MapUnit VCLUnoHelper::UnoEmbed2VCLMapUnit( sal_Int32 nUnoEmbedMapUnit )
|
|
|
|
{
|
|
|
|
switch( nUnoEmbedMapUnit )
|
|
|
|
{
|
|
|
|
case ::com::sun::star::embed::EmbedMapUnits::ONE_100TH_MM:
|
|
|
|
return MAP_100TH_MM;
|
|
|
|
case ::com::sun::star::embed::EmbedMapUnits::ONE_10TH_MM:
|
|
|
|
return MAP_10TH_MM;
|
|
|
|
case ::com::sun::star::embed::EmbedMapUnits::ONE_MM:
|
|
|
|
return MAP_MM;
|
|
|
|
case ::com::sun::star::embed::EmbedMapUnits::ONE_CM:
|
|
|
|
return MAP_CM;
|
|
|
|
case ::com::sun::star::embed::EmbedMapUnits::ONE_1000TH_INCH:
|
|
|
|
return MAP_1000TH_INCH;
|
|
|
|
case ::com::sun::star::embed::EmbedMapUnits::ONE_100TH_INCH:
|
|
|
|
return MAP_100TH_INCH;
|
|
|
|
case ::com::sun::star::embed::EmbedMapUnits::ONE_10TH_INCH:
|
|
|
|
return MAP_10TH_INCH;
|
|
|
|
case ::com::sun::star::embed::EmbedMapUnits::ONE_INCH:
|
|
|
|
return MAP_INCH;
|
|
|
|
case ::com::sun::star::embed::EmbedMapUnits::POINT:
|
|
|
|
return MAP_POINT;
|
|
|
|
case ::com::sun::star::embed::EmbedMapUnits::TWIP:
|
|
|
|
return MAP_TWIP;
|
|
|
|
case ::com::sun::star::embed::EmbedMapUnits::PIXEL:
|
|
|
|
return MAP_PIXEL;
|
|
|
|
}
|
|
|
|
|
2011-03-19 14:11:09 +01:00
|
|
|
OSL_FAIL( "Unexpected UNO map mode is provided!\n" );
|
2009-02-20 10:24:14 +00:00
|
|
|
return MAP_LASTENUMDUMMY;
|
|
|
|
}
|
|
|
|
|
|
|
|
sal_Int32 VCLUnoHelper::VCL2UnoEmbedMapUnit( MapUnit nVCLMapUnit )
|
|
|
|
{
|
|
|
|
switch( nVCLMapUnit )
|
|
|
|
{
|
|
|
|
case MAP_100TH_MM:
|
|
|
|
return ::com::sun::star::embed::EmbedMapUnits::ONE_100TH_MM;
|
|
|
|
case MAP_10TH_MM:
|
|
|
|
return ::com::sun::star::embed::EmbedMapUnits::ONE_10TH_MM;
|
|
|
|
case MAP_MM:
|
|
|
|
return ::com::sun::star::embed::EmbedMapUnits::ONE_MM;
|
|
|
|
case MAP_CM:
|
|
|
|
return ::com::sun::star::embed::EmbedMapUnits::ONE_CM;
|
|
|
|
case MAP_1000TH_INCH:
|
|
|
|
return ::com::sun::star::embed::EmbedMapUnits::ONE_1000TH_INCH;
|
|
|
|
case MAP_100TH_INCH:
|
|
|
|
return ::com::sun::star::embed::EmbedMapUnits::ONE_100TH_INCH;
|
|
|
|
case MAP_10TH_INCH:
|
|
|
|
return ::com::sun::star::embed::EmbedMapUnits::ONE_10TH_INCH;
|
|
|
|
case MAP_INCH:
|
|
|
|
return ::com::sun::star::embed::EmbedMapUnits::ONE_INCH;
|
|
|
|
case MAP_POINT:
|
|
|
|
return ::com::sun::star::embed::EmbedMapUnits::POINT;
|
|
|
|
case MAP_TWIP:
|
|
|
|
return ::com::sun::star::embed::EmbedMapUnits::TWIP;
|
|
|
|
case MAP_PIXEL:
|
|
|
|
return ::com::sun::star::embed::EmbedMapUnits::PIXEL;
|
|
|
|
default: ; // avoid compiler warning
|
|
|
|
}
|
|
|
|
|
2011-03-19 14:11:09 +01:00
|
|
|
OSL_FAIL( "Unexpected VCL map mode is provided!\n" );
|
2009-02-20 10:24:14 +00:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
using namespace ::com::sun::star::util;
|
|
|
|
|
|
|
|
//====================================================================
|
|
|
|
//= file-local helpers
|
|
|
|
//====================================================================
|
|
|
|
namespace
|
|
|
|
{
|
|
|
|
enum UnitConversionDirection
|
|
|
|
{
|
|
|
|
FieldUnitToMeasurementUnit,
|
|
|
|
MeasurementUnitToFieldUnit
|
|
|
|
};
|
|
|
|
|
|
|
|
sal_Int16 convertMeasurementUnit( sal_Int16 _nUnit, UnitConversionDirection eDirection, sal_Int16& _rFieldToUNOValueFactor )
|
|
|
|
{
|
|
|
|
static struct _unit_table
|
|
|
|
{
|
|
|
|
FieldUnit eFieldUnit;
|
|
|
|
sal_Int16 nMeasurementUnit;
|
|
|
|
sal_Int16 nFieldToMeasureFactor;
|
|
|
|
} aUnits[] = {
|
|
|
|
{ FUNIT_NONE, -1 , -1},
|
|
|
|
{ FUNIT_MM, MeasureUnit::MM, 1 }, // must precede MM_10TH
|
|
|
|
{ FUNIT_MM, MeasureUnit::MM_10TH, 10 },
|
|
|
|
{ FUNIT_100TH_MM, MeasureUnit::MM_100TH, 1 },
|
|
|
|
{ FUNIT_CM, MeasureUnit::CM, 1 },
|
|
|
|
{ FUNIT_M, MeasureUnit::M, 1 },
|
|
|
|
{ FUNIT_KM, MeasureUnit::KM, 1 },
|
|
|
|
{ FUNIT_TWIP, MeasureUnit::TWIP, 1 },
|
|
|
|
{ FUNIT_POINT, MeasureUnit::POINT, 1 },
|
|
|
|
{ FUNIT_PICA, MeasureUnit::PICA, 1 },
|
|
|
|
{ FUNIT_INCH, MeasureUnit::INCH, 1 }, // must precede INCH_*TH
|
|
|
|
{ FUNIT_INCH, MeasureUnit::INCH_10TH, 10 },
|
|
|
|
{ FUNIT_INCH, MeasureUnit::INCH_100TH, 100 },
|
|
|
|
{ FUNIT_INCH, MeasureUnit::INCH_1000TH, 1000 },
|
|
|
|
{ FUNIT_FOOT, MeasureUnit::FOOT, 1 },
|
|
|
|
{ FUNIT_MILE, MeasureUnit::MILE, 1 },
|
|
|
|
};
|
2010-10-18 12:28:33 +02:00
|
|
|
for ( size_t i = 0; i < SAL_N_ELEMENTS( aUnits ); ++i )
|
2009-02-20 10:24:14 +00:00
|
|
|
{
|
|
|
|
if ( eDirection == FieldUnitToMeasurementUnit )
|
|
|
|
{
|
|
|
|
if ( ( aUnits[ i ].eFieldUnit == (FieldUnit)_nUnit ) && ( aUnits[ i ].nFieldToMeasureFactor == _rFieldToUNOValueFactor ) )
|
|
|
|
return aUnits[ i ].nMeasurementUnit;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if ( aUnits[ i ].nMeasurementUnit == _nUnit )
|
|
|
|
{
|
|
|
|
_rFieldToUNOValueFactor = aUnits[ i ].nFieldToMeasureFactor;
|
|
|
|
return (sal_Int16)aUnits[ i ].eFieldUnit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ( eDirection == FieldUnitToMeasurementUnit )
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
_rFieldToUNOValueFactor = 1;
|
|
|
|
return (sal_Int16)FUNIT_NONE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//========================================================================
|
|
|
|
//= MeasurementUnitConversion
|
|
|
|
//========================================================================
|
|
|
|
//------------------------------------------------------------------------
|
|
|
|
sal_Int16 VCLUnoHelper::ConvertToMeasurementUnit( FieldUnit _nFieldUnit, sal_Int16 _nUNOToFieldValueFactor )
|
|
|
|
{
|
|
|
|
return convertMeasurementUnit( (sal_Int16)_nFieldUnit, FieldUnitToMeasurementUnit, _nUNOToFieldValueFactor );
|
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------
|
|
|
|
FieldUnit VCLUnoHelper::ConvertToFieldUnit( sal_Int16 _nMeasurementUnit, sal_Int16& _rFieldToUNOValueFactor )
|
|
|
|
{
|
|
|
|
return (FieldUnit)convertMeasurementUnit( _nMeasurementUnit, MeasurementUnitToFieldUnit, _rFieldToUNOValueFactor );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
MapUnit /* MapModeUnit */ VCLUnoHelper::ConvertToMapModeUnit(sal_Int16 /* com.sun.star.util.MeasureUnit.* */ _nMeasureUnit) throw (::com::sun::star::lang::IllegalArgumentException)
|
|
|
|
{
|
|
|
|
MapUnit eMode;
|
|
|
|
switch(_nMeasureUnit)
|
|
|
|
{
|
|
|
|
case com::sun::star::util::MeasureUnit::MM_100TH:
|
|
|
|
eMode = MAP_100TH_MM;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case com::sun::star::util::MeasureUnit::MM_10TH:
|
|
|
|
eMode = MAP_10TH_MM;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case com::sun::star::util::MeasureUnit::MM:
|
|
|
|
eMode = MAP_MM;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case com::sun::star::util::MeasureUnit::CM:
|
|
|
|
eMode = MAP_CM;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case com::sun::star::util::MeasureUnit::INCH_1000TH:
|
|
|
|
eMode = MAP_1000TH_INCH;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case com::sun::star::util::MeasureUnit::INCH_100TH:
|
|
|
|
eMode = MAP_100TH_INCH;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case com::sun::star::util::MeasureUnit::INCH_10TH:
|
|
|
|
eMode = MAP_10TH_INCH;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case com::sun::star::util::MeasureUnit::INCH:
|
|
|
|
eMode = MAP_INCH;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case com::sun::star::util::MeasureUnit::POINT:
|
|
|
|
eMode = MAP_POINT;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case com::sun::star::util::MeasureUnit::TWIP:
|
|
|
|
eMode = MAP_TWIP;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case com::sun::star::util::MeasureUnit::PIXEL:
|
|
|
|
eMode = MAP_PIXEL;
|
|
|
|
break;
|
|
|
|
|
|
|
|
/*
|
|
|
|
case com::sun::star::util::MeasureUnit::M:
|
|
|
|
break;
|
|
|
|
case com::sun::star::util::MeasureUnit::KM:
|
|
|
|
break;
|
|
|
|
case com::sun::star::util::MeasureUnit::PICA:
|
|
|
|
break;
|
|
|
|
case com::sun::star::util::MeasureUnit::FOOT:
|
|
|
|
break;
|
|
|
|
case com::sun::star::util::MeasureUnit::MILE:
|
|
|
|
break;
|
|
|
|
case com::sun::star::util::MeasureUnit::PERCENT:
|
|
|
|
break;
|
|
|
|
*/
|
|
|
|
case com::sun::star::util::MeasureUnit::APPFONT:
|
|
|
|
eMode = MAP_APPFONT;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case com::sun::star::util::MeasureUnit::SYSFONT:
|
|
|
|
eMode = MAP_SYSFONT;
|
|
|
|
break;
|
|
|
|
|
|
|
|
/*
|
|
|
|
case com::sun::star::util::MeasureUnit::RELATIVE:
|
|
|
|
eMode = MAP_RELATIVE;
|
|
|
|
break;
|
|
|
|
case com::sun::star::util::MeasureUnit::REALAPPFONT:
|
|
|
|
eMode = MAP_REALAPPFONT;
|
|
|
|
break;
|
|
|
|
*/
|
|
|
|
|
|
|
|
default:
|
2012-05-28 15:43:18 -05:00
|
|
|
throw ::com::sun::star::lang::IllegalArgumentException("Unsupported measure unit.", NULL, 1 );
|
2009-02-20 10:24:14 +00:00
|
|
|
}
|
|
|
|
return eMode;
|
|
|
|
}
|
|
|
|
|
|
|
|
::Size VCLUnoHelper::ConvertToVCLSize(com::sun::star::awt::Size const& _aSize)
|
|
|
|
{
|
|
|
|
::Size aVCLSize(_aSize.Width, _aSize.Height);
|
|
|
|
return aVCLSize;
|
|
|
|
}
|
|
|
|
|
|
|
|
com::sun::star::awt::Size VCLUnoHelper::ConvertToAWTSize(::Size /* VCLSize */ const& _aSize)
|
|
|
|
{
|
|
|
|
com::sun::star::awt::Size aAWTSize(_aSize.Width(), _aSize.Height());
|
|
|
|
return aAWTSize;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
::Point VCLUnoHelper::ConvertToVCLPoint(com::sun::star::awt::Point const& _aPoint)
|
|
|
|
{
|
|
|
|
::Point aVCLPoint(_aPoint.X, _aPoint.Y);
|
|
|
|
return aVCLPoint;
|
|
|
|
}
|
|
|
|
|
|
|
|
com::sun::star::awt::Point VCLUnoHelper::ConvertToAWTPoint(::Point /* VCLPoint */ const& _aPoint)
|
|
|
|
{
|
|
|
|
com::sun::star::awt::Point aAWTPoint(_aPoint.X(), _aPoint.Y());
|
|
|
|
return aAWTPoint;
|
|
|
|
}
|
|
|
|
|
CWS-TOOLING: integrate CWS dba32c
2009-06-29 20:53:25 +0200 fs r273484 : #i103138# Rectangle conversion
2009-06-29 20:51:50 +0200 fs r273483 : #i103138# yet more refactoring, now also setting the proper zoom level at the proper point in time
2009-06-29 13:40:26 +0200 fs r273470 : added svn:ignore to ignore output paths
2009-06-29 10:08:54 +0200 fs r273455 : #i103138#
refactored the code for positioning/zooming the control
Basically, we now allow adjustControlGeometry_throw (formerly known as positionControl_throw and setControlZoom) to
take an additional ViewTransformation parameter, describing the transformation to obtain the actual
control position/size. Consequently, positionControl itself also allows for a ViewTransformation parameter.
This has become necessary since during painting, the device which we created our control for might not necessarily
have a proper MapMode set. In this case, if we would use this map mode for calculating the control's position/size,
this would lead to wrong results.
Note that this problem was introduced by the fix for #i101398#: During the fix, we postponed the control creation
to a later time (when it is really needed). At this later time, the MapMode at the device is broken, at the earlier
time where we formerly crearted the control (createPrimitive2DSequence), it is not yet broken.
Whether or not the MapMode is defined as "broken" might depend on one's point of view, however ...
I consider it broken, since:
- we need the map mode to obtain the proper zoom level, which is to be forwarded to the control
- there are scenarios where the MapMode is *not* set to MAP_PIXEL (in those scenarios, everything works
fine), and there are scenarios where it *is* set to MAP_PIXEL (in those the bug 103138 appears).
It somehow feels wrong that one cannot rely on the device's map mode this way, but on the other hand
one has no possibility to obtain the current zoom by other means.
Note that one issue (still to be submitted) is left: In the page pane of a Draw/Impress document, controls
have a wrong text size. This is because in this pane, the above-mentioned "broken" map mode is used,
which means the controls have a zoom of "1:1" set, which is wrong here.
2009-06-25 13:41:35 +0200 msc r273380 : #100000# the tabs changed die to new properties
2009-06-24 12:42:40 +0200 msc r273330 : #102082# remove issue warning
2009-06-22 10:43:14 +0200 fs r273201 : createPrimitive2DSequence: care for being disposed
2009-06-18 12:35:13 +0200 oj r273109 : #i102305# make nooptfiles for gcc
2009-06-17 12:14:37 +0200 oj r273056 : #i102305# fix for linux
2009-06-17 07:20:22 +0200 oj r273046 : #i102305# move ValueTransfer into the for loop to avoid a crash under Linux
2009-06-17 07:17:28 +0200 oj r273045 : #i102305# use varchar
2009-06-15 14:11:27 +0200 fs r272983 : added since tag
2009-06-15 12:11:39 +0200 oj r272973 : #i102305# SAL_DLLPUBLIC_EXPORT inserted
2009-06-15 11:08:53 +0200 fs r272969 : #i10000#
2009-06-15 09:25:13 +0200 fs r272963 : merging fix for P1 issue #i102701#
2009-06-11 11:31:24 +0200 fs r272858 : #i10000# copied the fix which before the rebase was done in ../dialog/macropg.src
2009-06-11 09:38:14 +0200 fs r272846 : CWS-TOOLING: rebase CWS dba32c to trunk@272827 (milestone: DEV300:m50)
2009-06-02 09:53:10 +0200 fs r272483 : #i10000#
2009-05-29 15:55:03 +0200 fs r272465 : #i100818#
2009-05-29 12:58:43 +0200 fs r272452 : don't apply comphelper::getString on possibly VOID any
2009-05-29 10:38:35 +0200 oj r272437 : #i101519# handle where condition
2009-05-29 09:53:39 +0200 fs r272434 : #i100818# call into releaseStubs /without/ locked GlobalMutex
2009-05-28 07:53:44 +0200 oj r272375 : #i101369# parse tree changed
2009-05-27 14:53:36 +0200 fs r272347 : #i10000#
2009-05-27 09:29:15 +0200 oj r272327 : #i101626# check for double before hard cast
2009-05-27 09:13:58 +0200 oj r272326 : #i101626# handle void correctly
2009-05-27 08:04:39 +0200 oj r272321 : #i102256# wrong method signature used
2009-05-27 07:55:52 +0200 oj r272320 : #i101519# look up parameter typ if used in function
2009-05-27 06:49:07 +0200 oj r272319 : #i101519# set parameter from rowset as well
2009-05-26 13:30:56 +0200 oj r272297 : #i101987# impl XBatchExecution
2009-05-26 12:44:34 +0200 oj r272293 : #i101700# check if group is not set
2009-05-26 12:16:53 +0200 oj r272290 : #i101369# resolved some reduce7reduce problems with boolean_term and search_condition
2009-05-26 12:12:42 +0200 oj r272289 : #i101369# fix for or on one line criteria
2009-05-25 16:02:25 +0200 fs r272257 : #i999704# +PROPERTY_MOUSE_WHEEL_BEHAVIOR
2009-05-25 16:01:55 +0200 fs r272256 : merging the changes from CWS dba32b herein
2009-05-25 15:49:57 +0200 fs r272254 : #i999704#
2009-05-25 15:32:57 +0200 fs r272252 : #i99704# grid columns also to respect the MouseWheelBehavior property
2009-05-25 15:23:43 +0200 fs r272251 : don't pass empty Anys to ::comphelper::getString
2009-05-25 14:48:43 +0200 fs r272248 : merged changes from CWS dba32b herein
2009-05-25 14:44:40 +0200 fs r272247 : #i99704# support new MouseWheelBehavior property
2009-05-25 14:43:18 +0200 fs r272246 : #i99704# WheelWithoutFocus (peer property) superseded by MouseWheelBehavior (model property)
2009-05-25 14:41:03 +0200 fs r272245 : #i99704# no need to set the mouse wheel behavior at the peer, this is now a model property, having the right default
2009-05-25 14:39:31 +0200 fs r272243 : removed dead import
2009-05-25 14:35:36 +0200 fs r272242 : the new EnableVisible doesn't make sense for grid columns
2009-05-25 14:34:33 +0200 fs r272241 : #i99704# +MouseWheelBehavior - allow to enable/disable the mouse wheel for the control, or make it focus-dependent
2009-05-25 14:26:11 +0200 fs r272240 : #i99704# change MouseSettings wheel flag (NoWheelActionWithoutFocus) to a three-state option, allowing to completely ignore the mouse wheel
2009-05-23 21:35:59 +0200 fs r272213 : localize 'sub component opened/closed' event
2009-05-22 21:42:47 +0200 fs r272211 : #i102003#
2009-05-22 21:42:20 +0200 fs r272210 : grammar
2009-05-22 21:36:10 +0200 fs r272209 : #i102140# load only once, not twice, and show error messages during loading (and during any form action, that is) asynchronously
2009-05-22 21:35:11 +0200 fs r272208 : #i102140# +clear
2009-05-22 14:50:30 +0200 fs r272194 : #i102139# for newly created DB docs, set the MacroExecutionMode to USE_CONFIG
2009-05-22 12:03:42 +0200 fs r272180 : #i88878#
provided by noel.power@novell.com
implement a visibility property (EnableVisible) for toolkit controls, and usage in forms and UNO dialogs
2009-05-15 15:37:31 +0200 fs r271942 : #i100671# corrected some @since tags, so autodoc has better chances of correctly reading them
2009-05-15 15:33:11 +0200 fs r271940 : don't call comphelper::getFOO for VOID values
2009-05-15 15:08:31 +0200 fs r271937 : includes
2009-05-15 13:39:22 +0200 fs r271934 : #i101398# createPrimitive2DSequence: when we already have a control, use the old code. In particular, call positionControlForPaint
2009-05-15 12:33:48 +0200 fs r271933 : make the geometry a part of the ControlPrimitive2D's identity
2009-05-15 10:15:44 +0200 fs r271928 : #i10000#
2009-05-14 20:55:38 +0200 fs r271921 : #i101398# don't reuse the name PRIMITIVE_ID_CONTROLPRIMITIVE2D, make the name of our own ControlPrimitive2D unique
2009-05-14 20:55:31 +0200 fs r271920 : #i101398# don't reuse the name PRIMITIVE_ID_CONTROLPRIMITIVE2D, make the name of our own ControlPrimitive2D unique
2009-05-14 20:23:23 +0200 fs r271919 : #i101622#
2009-05-14 16:04:38 +0200 fs r271898 : don't use comphelper::getInt32 on voids
2009-05-14 16:04:12 +0200 fs r271897 : merge fix for issue whose number just slipped my memory ... (originally fixed in CWS dba32b)
2009-05-14 15:36:55 +0200 fs r271895 : merging changes from DEV300:m48
2009-05-07 14:43:19 +0200 fs r271670 : #i101477#
2009-05-07 14:37:30 +0200 fs r271668 : #i101477#
2009-05-07 09:27:30 +0200 oj r271628 : #i101343# remove pch
2009-05-06 09:36:02 +0200 fs r271568 : getFoo: diagnostics
2009-05-04 09:23:06 +0200 oj r271438 : CWS-TOOLING: rebase CWS dba32c to trunk@271427 (milestone: DEV300:m47)
2009-04-29 23:18:13 +0200 fs r271394 : #i101398# use a dedicated 2DPrimitive for UNO Controls, which is able to provide the B2DRange *without* actually creating the control
2009-04-29 13:52:25 +0200 fs r271366 : #i101308#
2009-07-03 14:21:50 +00:00
|
|
|
::Rectangle VCLUnoHelper::ConvertToVCLRect( ::com::sun::star::awt::Rectangle const & _rRect )
|
|
|
|
{
|
|
|
|
return ::Rectangle( _rRect.X, _rRect.Y, _rRect.X + _rRect.Width - 1, _rRect.Y + _rRect.Height - 1 );
|
|
|
|
}
|
2009-02-20 10:24:14 +00:00
|
|
|
|
CWS-TOOLING: integrate CWS dba32c
2009-06-29 20:53:25 +0200 fs r273484 : #i103138# Rectangle conversion
2009-06-29 20:51:50 +0200 fs r273483 : #i103138# yet more refactoring, now also setting the proper zoom level at the proper point in time
2009-06-29 13:40:26 +0200 fs r273470 : added svn:ignore to ignore output paths
2009-06-29 10:08:54 +0200 fs r273455 : #i103138#
refactored the code for positioning/zooming the control
Basically, we now allow adjustControlGeometry_throw (formerly known as positionControl_throw and setControlZoom) to
take an additional ViewTransformation parameter, describing the transformation to obtain the actual
control position/size. Consequently, positionControl itself also allows for a ViewTransformation parameter.
This has become necessary since during painting, the device which we created our control for might not necessarily
have a proper MapMode set. In this case, if we would use this map mode for calculating the control's position/size,
this would lead to wrong results.
Note that this problem was introduced by the fix for #i101398#: During the fix, we postponed the control creation
to a later time (when it is really needed). At this later time, the MapMode at the device is broken, at the earlier
time where we formerly crearted the control (createPrimitive2DSequence), it is not yet broken.
Whether or not the MapMode is defined as "broken" might depend on one's point of view, however ...
I consider it broken, since:
- we need the map mode to obtain the proper zoom level, which is to be forwarded to the control
- there are scenarios where the MapMode is *not* set to MAP_PIXEL (in those scenarios, everything works
fine), and there are scenarios where it *is* set to MAP_PIXEL (in those the bug 103138 appears).
It somehow feels wrong that one cannot rely on the device's map mode this way, but on the other hand
one has no possibility to obtain the current zoom by other means.
Note that one issue (still to be submitted) is left: In the page pane of a Draw/Impress document, controls
have a wrong text size. This is because in this pane, the above-mentioned "broken" map mode is used,
which means the controls have a zoom of "1:1" set, which is wrong here.
2009-06-25 13:41:35 +0200 msc r273380 : #100000# the tabs changed die to new properties
2009-06-24 12:42:40 +0200 msc r273330 : #102082# remove issue warning
2009-06-22 10:43:14 +0200 fs r273201 : createPrimitive2DSequence: care for being disposed
2009-06-18 12:35:13 +0200 oj r273109 : #i102305# make nooptfiles for gcc
2009-06-17 12:14:37 +0200 oj r273056 : #i102305# fix for linux
2009-06-17 07:20:22 +0200 oj r273046 : #i102305# move ValueTransfer into the for loop to avoid a crash under Linux
2009-06-17 07:17:28 +0200 oj r273045 : #i102305# use varchar
2009-06-15 14:11:27 +0200 fs r272983 : added since tag
2009-06-15 12:11:39 +0200 oj r272973 : #i102305# SAL_DLLPUBLIC_EXPORT inserted
2009-06-15 11:08:53 +0200 fs r272969 : #i10000#
2009-06-15 09:25:13 +0200 fs r272963 : merging fix for P1 issue #i102701#
2009-06-11 11:31:24 +0200 fs r272858 : #i10000# copied the fix which before the rebase was done in ../dialog/macropg.src
2009-06-11 09:38:14 +0200 fs r272846 : CWS-TOOLING: rebase CWS dba32c to trunk@272827 (milestone: DEV300:m50)
2009-06-02 09:53:10 +0200 fs r272483 : #i10000#
2009-05-29 15:55:03 +0200 fs r272465 : #i100818#
2009-05-29 12:58:43 +0200 fs r272452 : don't apply comphelper::getString on possibly VOID any
2009-05-29 10:38:35 +0200 oj r272437 : #i101519# handle where condition
2009-05-29 09:53:39 +0200 fs r272434 : #i100818# call into releaseStubs /without/ locked GlobalMutex
2009-05-28 07:53:44 +0200 oj r272375 : #i101369# parse tree changed
2009-05-27 14:53:36 +0200 fs r272347 : #i10000#
2009-05-27 09:29:15 +0200 oj r272327 : #i101626# check for double before hard cast
2009-05-27 09:13:58 +0200 oj r272326 : #i101626# handle void correctly
2009-05-27 08:04:39 +0200 oj r272321 : #i102256# wrong method signature used
2009-05-27 07:55:52 +0200 oj r272320 : #i101519# look up parameter typ if used in function
2009-05-27 06:49:07 +0200 oj r272319 : #i101519# set parameter from rowset as well
2009-05-26 13:30:56 +0200 oj r272297 : #i101987# impl XBatchExecution
2009-05-26 12:44:34 +0200 oj r272293 : #i101700# check if group is not set
2009-05-26 12:16:53 +0200 oj r272290 : #i101369# resolved some reduce7reduce problems with boolean_term and search_condition
2009-05-26 12:12:42 +0200 oj r272289 : #i101369# fix for or on one line criteria
2009-05-25 16:02:25 +0200 fs r272257 : #i999704# +PROPERTY_MOUSE_WHEEL_BEHAVIOR
2009-05-25 16:01:55 +0200 fs r272256 : merging the changes from CWS dba32b herein
2009-05-25 15:49:57 +0200 fs r272254 : #i999704#
2009-05-25 15:32:57 +0200 fs r272252 : #i99704# grid columns also to respect the MouseWheelBehavior property
2009-05-25 15:23:43 +0200 fs r272251 : don't pass empty Anys to ::comphelper::getString
2009-05-25 14:48:43 +0200 fs r272248 : merged changes from CWS dba32b herein
2009-05-25 14:44:40 +0200 fs r272247 : #i99704# support new MouseWheelBehavior property
2009-05-25 14:43:18 +0200 fs r272246 : #i99704# WheelWithoutFocus (peer property) superseded by MouseWheelBehavior (model property)
2009-05-25 14:41:03 +0200 fs r272245 : #i99704# no need to set the mouse wheel behavior at the peer, this is now a model property, having the right default
2009-05-25 14:39:31 +0200 fs r272243 : removed dead import
2009-05-25 14:35:36 +0200 fs r272242 : the new EnableVisible doesn't make sense for grid columns
2009-05-25 14:34:33 +0200 fs r272241 : #i99704# +MouseWheelBehavior - allow to enable/disable the mouse wheel for the control, or make it focus-dependent
2009-05-25 14:26:11 +0200 fs r272240 : #i99704# change MouseSettings wheel flag (NoWheelActionWithoutFocus) to a three-state option, allowing to completely ignore the mouse wheel
2009-05-23 21:35:59 +0200 fs r272213 : localize 'sub component opened/closed' event
2009-05-22 21:42:47 +0200 fs r272211 : #i102003#
2009-05-22 21:42:20 +0200 fs r272210 : grammar
2009-05-22 21:36:10 +0200 fs r272209 : #i102140# load only once, not twice, and show error messages during loading (and during any form action, that is) asynchronously
2009-05-22 21:35:11 +0200 fs r272208 : #i102140# +clear
2009-05-22 14:50:30 +0200 fs r272194 : #i102139# for newly created DB docs, set the MacroExecutionMode to USE_CONFIG
2009-05-22 12:03:42 +0200 fs r272180 : #i88878#
provided by noel.power@novell.com
implement a visibility property (EnableVisible) for toolkit controls, and usage in forms and UNO dialogs
2009-05-15 15:37:31 +0200 fs r271942 : #i100671# corrected some @since tags, so autodoc has better chances of correctly reading them
2009-05-15 15:33:11 +0200 fs r271940 : don't call comphelper::getFOO for VOID values
2009-05-15 15:08:31 +0200 fs r271937 : includes
2009-05-15 13:39:22 +0200 fs r271934 : #i101398# createPrimitive2DSequence: when we already have a control, use the old code. In particular, call positionControlForPaint
2009-05-15 12:33:48 +0200 fs r271933 : make the geometry a part of the ControlPrimitive2D's identity
2009-05-15 10:15:44 +0200 fs r271928 : #i10000#
2009-05-14 20:55:38 +0200 fs r271921 : #i101398# don't reuse the name PRIMITIVE_ID_CONTROLPRIMITIVE2D, make the name of our own ControlPrimitive2D unique
2009-05-14 20:55:31 +0200 fs r271920 : #i101398# don't reuse the name PRIMITIVE_ID_CONTROLPRIMITIVE2D, make the name of our own ControlPrimitive2D unique
2009-05-14 20:23:23 +0200 fs r271919 : #i101622#
2009-05-14 16:04:38 +0200 fs r271898 : don't use comphelper::getInt32 on voids
2009-05-14 16:04:12 +0200 fs r271897 : merge fix for issue whose number just slipped my memory ... (originally fixed in CWS dba32b)
2009-05-14 15:36:55 +0200 fs r271895 : merging changes from DEV300:m48
2009-05-07 14:43:19 +0200 fs r271670 : #i101477#
2009-05-07 14:37:30 +0200 fs r271668 : #i101477#
2009-05-07 09:27:30 +0200 oj r271628 : #i101343# remove pch
2009-05-06 09:36:02 +0200 fs r271568 : getFoo: diagnostics
2009-05-04 09:23:06 +0200 oj r271438 : CWS-TOOLING: rebase CWS dba32c to trunk@271427 (milestone: DEV300:m47)
2009-04-29 23:18:13 +0200 fs r271394 : #i101398# use a dedicated 2DPrimitive for UNO Controls, which is able to provide the B2DRange *without* actually creating the control
2009-04-29 13:52:25 +0200 fs r271366 : #i101308#
2009-07-03 14:21:50 +00:00
|
|
|
::com::sun::star::awt::Rectangle VCLUnoHelper::ConvertToAWTRect( ::Rectangle const & _rRect )
|
|
|
|
{
|
|
|
|
return ::com::sun::star::awt::Rectangle( _rRect.Left(), _rRect.Top(), _rRect.GetWidth(), _rRect.GetHeight() );
|
|
|
|
}
|
CWS-TOOLING: integrate CWS dba32g
2009-09-09 07:53:55 +0200 oj r275964 : replace strlen with rtl_str_getLength
2009-09-07 20:59:10 +0200 fs r275913 : disable the CopyTableWizard test until issue 104869 is fixed
2009-09-07 12:17:31 +0200 oj r275885 : #i104810# remove de as lang
2009-09-05 22:26:21 +0200 fs r275857 : protect StateChanged against re-entrance
2009-09-05 22:25:52 +0200 fs r275856 : don't attempt to classify the parent of a form as control
2009-09-05 22:25:29 +0200 fs r275855 : protect against re-entrance
2009-09-05 00:11:40 +0200 fs r275835 : #i10000#
2009-09-04 23:25:50 +0200 fs r275834 : #i10000#
2009-09-04 23:23:47 +0200 fs r275833 : #i10000#
2009-09-04 21:49:37 +0200 fs r275830 : #i10000# correct wrong conflict resolution
2009-09-04 20:59:51 +0200 fs r275829 : CWS-TOOLING: rebase CWS dba32g to trunk@275801 (milestone: DEV300:m57)
2009-09-04 11:08:32 +0200 oj r275791 : #i104780# new version 1.2.0
2009-09-03 22:29:21 +0200 fs r275775 : OSL_TRACE doesn't need \n anymore
2009-09-03 08:33:21 +0200 fs r275743 : CWS-TOOLING: rebase CWS dba32g to trunk@275331 (milestone: DEV300:m56)
2009-09-02 13:48:12 +0200 fs r275708 : removed useless include
2009-09-02 13:45:43 +0200 fs r275707 : more since tags, which are used across offapi/udkapi
2009-09-02 13:23:04 +0200 fs r275705 : should *not* have the dtor, copy ctor, and assignment operator compiler-generated, else we run into trouble as soon as the compiler creates different versions of our singleton member's static data in different libraries
2009-09-02 12:32:45 +0200 fs r275704 : AutoIncrementIsPrimaryKey is a driver setting, not a data source setting
2009-09-02 11:42:49 +0200 fs r275701 : URL meta data are meta data which are valid for all connections of this type, not per-data-source properties. Settings them as data source properties is a hack.
2009-09-02 08:43:34 +0200 fs r275696 : 3.x.x is not a valid 'since' tag
2009-09-01 16:05:24 +0200 fs r275665 : #i104686# don't treat controls bound to read-only columns as required
2009-09-01 13:10:22 +0200 fs r275657 : #i104574# use PageUp/Down to scroll through the complete page
2009-09-01 07:04:48 +0200 oj r275641 : #i104104# correct line ends
2009-08-31 15:52:34 +0200 fs r275612 : #i104410#
2009-08-31 12:29:05 +0200 fs r275596 : #i104364#
2009-08-31 12:28:56 +0200 fs r275595 : #i104364#
2009-08-31 11:43:09 +0200 fs r275593 : #i104649# JavaDriverClassPath is also a known JDBC-bridge setting
2009-08-31 11:41:37 +0200 fs r275592 : #i104649#
2009-08-28 21:48:27 +0200 fs r275552 : during #i96862#: renamed the configuration data which controls availability of certain DBA-related UI
2009-08-28 21:48:17 +0200 fs r275551 : #i96862# do not show the 'Create a new database' option when a) no embedded/dBase driver is installed or b) the configuration requests to hide the option
2009-08-28 21:47:19 +0200 fs r275550 : during #i96862#: renamed the configuration data which controls availability of certain DBA-related UI
2009-08-28 21:46:41 +0200 fs r275549 : #i96862# renamed and extended the configuration data which controls availability of certain DBA-related UI
2009-08-28 15:10:19 +0200 fs r275535 : #i96862# if no embedded driver is installed, use dBase for creating new DBs. If no dBase driver is installed, too, do not offer the 'Create new database' option
2009-08-28 14:03:04 +0200 fs r275532 : #i104454# allow multiple fields to display the same column
2009-08-28 13:14:00 +0200 fs r275528 : #i104584# driver meta data do not belong into a data source's settings
2009-08-28 13:09:57 +0200 fs r275527 : properly chech the MySQL type buttons (else next/back in the wizard leads to state with two buttons checked)
2009-08-28 13:09:17 +0200 fs r275526 : #i104584# driver meta data do not belong into a data source's settings
2009-08-28 13:07:18 +0200 fs r275525 : BooleanComparisonMode is a property, or a feature - but not a driver meta data
2009-08-28 11:00:31 +0200 fs r275521 : #i104580#
2009-08-28 10:40:05 +0200 fs r275519 : #i104577# correct assertion: If the template node type is ANY, then any value type is allowed
2009-08-28 10:09:30 +0200 fs r275518 : #i104575# implement Named Pipe UI
2009-08-28 10:09:07 +0200 fs r275517 : pass the trigger-event to IWindowOperator::operateOn / work with VclWindowEvents, not VclSimpleEvents
2009-08-27 14:27:36 +0200 fs r275484 : ImplPosTabPage: respect mbEmptyViewMargin for WINDOWALIGN_LEFT
2009-08-27 13:43:56 +0200 fs r275480 : merging latest changes from CWS dba32f herein
2009-08-27 13:23:07 +0200 fs r275475 : #i103882#
2009-08-27 11:56:55 +0200 fs r275466 : #i104544# SetState: Do not call Update at the window which we just set text for. It should (sic\!) not be needed, but causes trouble
2009-08-27 11:55:34 +0200 fs r275465 : #i104544#
do not allow re-entrance for impl_ensureControl_nothrow
Actually, this is part of the fix only. I also removed the code which triggered this re-entrance (from
the grid control implementation), but to ensure it won't happen, again, I added some safety herein.
2009-08-27 10:14:11 +0200 fs r275459 : preparations for supporting a 'NamedPipe' parameter for the MySQL Connector/OOo
2009-08-27 10:13:21 +0200 fs r275458 : preparations for supporting a 'NamedPipe' setting for the MySQL Connector/OOo
2009-08-27 10:11:14 +0200 fs r275456 : outsourced the MySQLNative settings into a dedicated class, to not duplicate all the code in two tab page implementations
2009-08-26 14:18:13 +0200 fs r275422 : #i10000#
2009-08-26 13:26:36 +0200 fs r275419 : ignore output paths
2009-08-26 13:23:38 +0200 fs r275417 : support the LocalSocket property for the MySQL native driver
2009-08-26 13:17:05 +0200 fs r275416 : some re-factoring, to outsource the tab page for setting up the MySQLNative connection, into a dedicated class (needed later)
2009-08-26 13:15:15 +0200 fs r275415 : support a NoThousandSep property for NumericFormatters - I'm tired of correcting this at runtime, instead of controlling it in the resource
2009-08-26 11:45:08 +0200 fs r275410 : oops, 'flat' shouldn't have got lost
2009-08-26 09:38:57 +0200 fs r275398 : #i102631# when saving the document fails, ensure that the interaction handler really can handle/display the error
2009-08-26 09:37:05 +0200 fs r275397 : #i102631# don't let non-IO/RuntimeExceptions escape from DatabaseDocument::store*, wrap them into an IOException
2009-08-26 09:35:39 +0200 fs r275395 : let the default interaction handler implement XInteractionHandler2
2009-08-25 13:51:34 +0200 fs r275352 : #i102631# createTempFile: pass URL through FileHelper.getOOoCompatibleFileURL
2009-08-25 13:49:23 +0200 fs r275351 : #i102631# createTempFileURL: immediately delete the file implicitly created by createTempFile, we really only need the URL
2009-08-24 14:49:07 +0200 fs r275318 : #i10000#
2009-08-24 14:36:03 +0200 fs r275315 : properly terminate message with 0 character
2009-08-24 14:35:45 +0200 fs r275314 : trace method concepts in non-pro, if special flag is enabled
2009-08-24 14:24:17 +0200 fs r275312 : #i98973# filter some more events for grid control columns
2009-08-24 14:15:23 +0200 fs r275311 : #i98973# implement XComboBox for combo box cells
2009-08-24 13:39:24 +0200 fs r275308 : #i98973# do not display the 'actionPerformed' event for grid combo box columns
2009-08-24 12:52:03 +0200 fs r275303 : #i98973# implement XCheckBox and XButton for check box cells
2009-08-24 11:56:05 +0200 oj r275300 : #i104447# wrong default for orientation
2009-08-24 10:51:21 +0200 fs r275296 : in the script selector dialog, interpret a double click onto a function as OK
2009-08-24 10:50:56 +0200 fs r275295 : localize some to-be-displayed names, consolidate some code regarding form/control naming
2009-08-21 14:28:05 +0200 fs r275255 : #i98973# implement KeyListeners
2009-08-21 14:27:20 +0200 fs r275254 : #i98973# move the conversion VCL[Mouse|Key]Event->Awt[Mouse|Key]Event from vclxwindow.cxx to VCLUnoHelper
2009-08-21 14:08:50 +0200 fs r275248 : #i98973# implement Mouse- and MouseMotion-broadcasting
2009-08-21 13:31:08 +0200 fs r275244 : #i98973# implement text and change listeners at text cells
2009-08-21 12:47:38 +0200 fs r275234 : #i104399# some refactoring:
If the MySQL Connector/OOo is installed, it registers for the sdbc:mysqlc: protocol (now known as DST_MYSQL_NATIVE_DIRECT).
However, we do not want to display this in the UI, instead we display "MySQL" only, which collects DST_MYSQL_ODBC, DST_MYSQL_JDBC, and DST_MYSQL_NATIVE.
2009-08-21 12:45:18 +0200 fs r275232 : #i104399# also register for the sdbc:mysql:mysqlc protocol, decide at runtime (depending on the availability of sdbc:mysqlc:), whether it is really accepted. This prevents that the C/OOo extension needs to register *our* implementation name for the sdbc:mysql:mysqlc: protocol, which would be somewhat weird
2009-08-20 16:18:48 +0200 fs r275190 : merging the latest changes from CWS dba32f (which this CWS was created from)
2009-08-19 20:19:59 +0200 fs r275160 : add some spacing between the radios
2009-08-19 14:50:15 +0200 fs r275150 : #i98973# slightly refactoring the grid cell implementations, to prepare for proper events being fired. Implement focus events for the moment, more to come.
2009-08-19 10:53:38 +0200 fs r275142 : #i99936# initialize newly created models
2009-08-18 23:03:48 +0200 fs r275132 : merging latest changes from CWS dba32f
2009-08-18 15:14:08 +0200 fs r275110 : #i102819# SetColumnPos: SCROLL_CLIP is deadly here
2009-09-14 11:18:01 +00:00
|
|
|
|
|
|
|
awt::MouseEvent VCLUnoHelper::createMouseEvent( const ::MouseEvent& _rVclEvent, const uno::Reference< uno::XInterface >& _rxContext )
|
|
|
|
{
|
|
|
|
awt::MouseEvent aMouseEvent;
|
|
|
|
aMouseEvent.Source = _rxContext;
|
|
|
|
|
|
|
|
aMouseEvent.Modifiers = 0;
|
|
|
|
if ( _rVclEvent.IsShift() )
|
|
|
|
aMouseEvent.Modifiers |= ::com::sun::star::awt::KeyModifier::SHIFT;
|
|
|
|
if ( _rVclEvent.IsMod1() )
|
|
|
|
aMouseEvent.Modifiers |= ::com::sun::star::awt::KeyModifier::MOD1;
|
|
|
|
if ( _rVclEvent.IsMod2() )
|
|
|
|
aMouseEvent.Modifiers |= ::com::sun::star::awt::KeyModifier::MOD2;
|
|
|
|
|
|
|
|
aMouseEvent.Buttons = 0;
|
|
|
|
if ( _rVclEvent.IsLeft() )
|
|
|
|
aMouseEvent.Buttons |= ::com::sun::star::awt::MouseButton::LEFT;
|
|
|
|
if ( _rVclEvent.IsRight() )
|
|
|
|
aMouseEvent.Buttons |= ::com::sun::star::awt::MouseButton::RIGHT;
|
|
|
|
if ( _rVclEvent.IsMiddle() )
|
|
|
|
aMouseEvent.Buttons |= ::com::sun::star::awt::MouseButton::MIDDLE;
|
|
|
|
|
|
|
|
aMouseEvent.X = _rVclEvent.GetPosPixel().X();
|
|
|
|
aMouseEvent.Y = _rVclEvent.GetPosPixel().Y();
|
|
|
|
aMouseEvent.ClickCount = _rVclEvent.GetClicks();
|
|
|
|
aMouseEvent.PopupTrigger = sal_False;
|
|
|
|
|
|
|
|
return aMouseEvent;
|
|
|
|
}
|
|
|
|
|
|
|
|
awt::KeyEvent VCLUnoHelper::createKeyEvent( const ::KeyEvent& _rVclEvent, const uno::Reference< uno::XInterface >& _rxContext )
|
|
|
|
{
|
|
|
|
awt::KeyEvent aKeyEvent;
|
|
|
|
aKeyEvent.Source = _rxContext;
|
|
|
|
|
|
|
|
aKeyEvent.Modifiers = 0;
|
|
|
|
if ( _rVclEvent.GetKeyCode().IsShift() )
|
|
|
|
aKeyEvent.Modifiers |= awt::KeyModifier::SHIFT;
|
|
|
|
if ( _rVclEvent.GetKeyCode().IsMod1() )
|
|
|
|
aKeyEvent.Modifiers |= awt::KeyModifier::MOD1;
|
|
|
|
if ( _rVclEvent.GetKeyCode().IsMod2() )
|
|
|
|
aKeyEvent.Modifiers |= awt::KeyModifier::MOD2;
|
|
|
|
if ( _rVclEvent.GetKeyCode().IsMod3() )
|
|
|
|
aKeyEvent.Modifiers |= awt::KeyModifier::MOD3;
|
|
|
|
|
|
|
|
aKeyEvent.KeyCode = _rVclEvent.GetKeyCode().GetCode();
|
|
|
|
aKeyEvent.KeyChar = _rVclEvent.GetCharCode();
|
|
|
|
aKeyEvent.KeyFunc = ::sal::static_int_cast< sal_Int16 >( _rVclEvent.GetKeyCode().GetFunction());
|
|
|
|
|
|
|
|
return aKeyEvent;
|
|
|
|
}
|
2010-10-14 08:27:31 +02:00
|
|
|
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|