2752 Commits

Author SHA1 Message Date
Matthias Kuhn
af709503d5 Cache svg paths
Rebuilding them for each access from the settings is costly
2020-12-24 10:13:12 +07:00
Alessandro Pasotti
e520af3c01
Merge pull request #40726 from elpaso/connections-api-results-iterator
Connections API: execSql iterator
2020-12-23 13:18:44 +01:00
Nyall Dawson
890491976c Replace ArcGIS REST data source manager list with a view based on the browser model
This has MANY benefits:
- Shows the merged feature service/map service view we use in browser
- Avoids the HUGE main thread ui hang when connecting to servers with
many layers (could be 20 mins+ for some services)
- Avoids bombing out and showing incomplete lists when a server reports
an error when connecting to any of the services it advertises (happens
often)
2020-12-23 16:10:05 +10:00
Loïc Bartoletti
817744928c
Fix circle by three tangents parrallel when two are parallels (#40702)
* add new method to solve QgsCircle::from3tangents where 2 tangents are parallels
2020-12-23 09:00:15 +10:00
Matthias Kuhn
b4f14d5df5 Fix docstring 2020-12-23 05:40:35 +10:00
Alessandro Pasotti
d5b65902c5 hasNextRow 2020-12-22 19:32:33 +01:00
Alessandro Pasotti
0978ff22f9 Connections API: execSql iterator 2020-12-22 16:53:42 +01:00
Juergen E. Fischer
b28d820b0c fix typos 2020-12-22 00:03:34 +01:00
Nyall Dawson
da59316fb5 Use /TransferBack/ instead of /Factory/ in layout registry factory methods
For same reason as we do in Processing registry:

(from the comments included in this commit)
"
While it seems like /Factory/ would be the correct annotations here, that's not
the case.
As per Phil Thomson's advice on https://www.riverbankcomputing.com/pipermail/pyqt/2017-July/039450.html:

"
/Factory/ is used when the instance returned is guaranteed to be new to Python.
In this case it isn't because it has already been seen when being returned by QgsProcessingAlgorithm::createInstance()
(However for a different sub-class implemented in C++ then it would be the first time it was seen
by Python so the /Factory/ on create() would be correct.)

You might try using /TransferBack/ on create() instead - that might be the best compromise.
"
2020-12-22 06:27:17 +10:00
Ivan Ivanov
a05971d5d3 Added bool supportsEditing property to QgsVectorLayer 2020-12-22 06:26:43 +10:00
Nyall Dawson
7380f8d841 Spelling 2020-12-22 04:01:32 +10:00
Nyall Dawson
d8784602f5 Add method to retrieve filtered group content 2020-12-22 04:01:32 +10:00
Nyall Dawson
8b313f8443 Method to retrieve all group content 2020-12-22 04:01:32 +10:00
Nyall Dawson
23b1533d58 Add api to retrieve user groups 2020-12-22 04:01:32 +10:00
Nyall Dawson
d6fa53310b Start on QgsArcGisPortalUtils 2020-12-22 04:01:32 +10:00
Alessandro Pasotti
5a2cfe563c
Merge pull request #40663 from elpaso/connections-api-executeSql-with-column-names
Connections API: execSql, return rows and column names
2020-12-21 13:39:45 +01:00
Alessandro Pasotti
a277cc6332 QgsAbstractDatabaseProviderConnection::QueryResult proper encapsulation
and rename to execSql
2020-12-21 10:43:51 +01:00
Juergen E. Fischer
7719668453 fix build (take II; followup 1c9d89a7c3d) 2020-12-19 22:57:54 +01:00
Nyall Dawson
2ec448053f Add option to render color ramp legend items as horizontal bars 2020-12-19 05:28:20 +10:00
Nyall Dawson
eaea2aaf10 Allow users to set text format for ramp legend labels 2020-12-19 05:28:20 +10:00
Alessandro Pasotti
84131e0cfc Connections API: executeSqlWithNames, return column names
This is mainly useful for Python, this way we can probably
avoid calling fields() and all related cost when all we need
is colum names for display.

I'm not very happy with the method name and I would probably just
drop the old signature for executeSql and replace it with the new
one, unfortunately is public API.

But if everybody is happy we could consider an API break.
2020-12-18 18:15:27 +01:00
Nyall Dawson
13e4969817 Try to fix doc test 2020-12-18 18:14:49 +10:00
Nyall Dawson
99208ab45b Split query related functions out into a separate file 2020-12-18 18:14:49 +10:00
Nyall Dawson
8d45910535 Move QgsArcGisRestUtils to core, cleanup API, add docs and selectively
expose to Python
2020-12-18 18:14:49 +10:00
Nyall Dawson
2f2e410d0d Minor doc correction, tweak equality operator to consider original units 2020-12-18 18:14:29 +10:00
Samweli
6ae1bf22c6 Add API to set/retrieve original units in QgsInterval 2020-12-18 18:14:29 +10:00
Nyall Dawson
24549f05fd Allow customisation of color ramp legend items in a print layout legend 2020-12-18 12:03:26 +10:00
Nyall Dawson
8eb9448746 Prefix/suffix support, ensure correct size determination of legend text 2020-12-18 12:03:26 +10:00
Nyall Dawson
a0accab0c2 Add QgsColorRampLegendNodeSettings to QgsSingleBandGrayRenderer 2020-12-18 12:03:26 +10:00
Nyall Dawson
f96ba98bb8 Use QgsColorRampLegendNodeSettings to control settings for QgsColorRampLegendNode items 2020-12-18 12:03:26 +10:00
Nyall Dawson
45d2edda16 QgsColorRampShader can have color ramp legend node settings 2020-12-18 12:03:26 +10:00
Nyall Dawson
e48286c0d4 Pass QgsReadWriteContext onto QgsColorRampShader read/writeXml methods 2020-12-18 12:03:26 +10:00
Nyall Dawson
3fec67ac2c Add QgsColorRampLegendNodeSettings class 2020-12-18 12:03:26 +10:00
Nyall Dawson
60aea700d1 Forward declare more classes 2020-12-18 12:03:26 +10:00
Nyall Dawson
1be1229663 Forward declare 2020-12-18 12:03:26 +10:00
Matthias Kuhn
c56d2d8d88
Merge pull request #40628 from m-kuhn/timeout_disable
Allow disabling QgsNetworkAccessManager timeout functionality
2020-12-17 08:58:04 +01:00
Nyall Dawson
0d7b95fa67 Generate more descriptive legends for raster layers
- include band name details where its useful
- create a legend for multiband raster renderer
2020-12-17 04:57:56 +10:00
Matthias Kuhn
7388e67bd0 Allow disabling QgsNetworkAccessManager timeout functionality
by setting the timout to 0

This can be interesting to overcome the limitations of the timeout
functionality by replacing it with QNetworkAccessManager::setTransferTimeout.
E.g. to have more than 6 downloads running in parallel.
2020-12-16 19:08:10 +01:00
Nyall Dawson
d7ce1a3167 Create color ramp legend nodes for pseudocolor or grayscale rasters or
point clouds using a Linear color ramp based renderer
2020-12-16 18:46:53 +10:00
Nyall Dawson
e4a91e7659 Add missing sip casts for legend nodes 2020-12-16 18:46:53 +10:00
Nyall Dawson
869b24ea92 Add new QgsColorRampLegendNode class for rendering a color ramp item as a legend node 2020-12-16 18:46:53 +10:00
nirvn
d03d3b3ea0 [FEATURE][locator] Add delayed fetching of results 2020-12-16 13:14:27 +07:00
Nyall Dawson
7b141e92f0 Also add scaling factor option, test 2020-12-16 13:58:20 +10:00
Nyall Dawson
9fc11d93c7 Add a trigger3DUpdate method to QgsMapLayer so that an explicit update of the layer in 3d maps can be requested
This is the 3d equivalent of QgsMapLayer::triggerUpdate()
2020-12-16 13:58:20 +10:00
Nyall Dawson
1963ef9784 [pointclouds] Add an elevation tab in layer properties, and allow
users to set a manual offset to apply to point cloud z values

This allows for adjustment of the elevation of point clouds, eg so that:
1. They match nicely with point clouds from other datasources
2. Users can use point clouds from sources with arbitrary z values,
eg. a point cloud made by opendronemap without any actual reference
z values available
2020-12-16 13:58:20 +10:00
Peter Petrik
221bd2f68f
untwine pdalprovider integration (#40404)
[pointclouds] untwine pdalprovider integration
2020-12-15 14:25:09 +01:00
nirvn
a057e56fd3 Address review 2020-12-15 13:47:43 +07:00
nirvn
ebc2695dc1 [FEATURE][geocoder] Add a nominatim API geocoder 2020-12-15 13:47:43 +07:00
Nyall Dawson
3a3e771d04 Cache google maps geocoder results so that we don't send the same
request multiple times
2020-12-15 14:22:59 +10:00
Nyall Dawson
df28e637cd Fix see also link 2020-12-14 16:49:48 +10:00