Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add API for QGIS symbol -> FSL symbol conversion #64

Merged
merged 60 commits into from
May 15, 2024
Merged
Changes from 1 commit
Commits
Show all changes
60 commits
Select commit Hold shift + click to select a range
2e8c311
Start on symbol to FSL converter
nyalldawson Apr 29, 2024
0bb7e31
Simple fill conversion
nyalldawson Apr 29, 2024
f956ca2
Shapeburst fill
nyalldawson Apr 29, 2024
82e737d
Gradient fill
nyalldawson Apr 29, 2024
5f424b2
Line pattern fill
nyalldawson Apr 30, 2024
95119de
More symbol layer types
nyalldawson Apr 30, 2024
0d0ded2
Ellipse marker
nyalldawson Apr 30, 2024
9fff3f7
Font marker, svg marker
nyalldawson Apr 30, 2024
50e86b9
Finish fill support, marker line
nyalldawson Apr 30, 2024
d1badd0
Complete QGIS -> FSL symbol conversion
nyalldawson Apr 30, 2024
ce89af0
Lint
nyalldawson Apr 30, 2024
12d90ae
Lint
nyalldawson Apr 30, 2024
228034f
Lint
nyalldawson Apr 30, 2024
0a9911f
Refine test matrix
nyalldawson May 1, 2024
5bf319f
Start on renderer conversion
nyalldawson May 2, 2024
9a630c4
Convert categorized renderers
nyalldawson May 2, 2024
88d5689
Convert graduated renderers
nyalldawson May 2, 2024
c6d86ef
Lint
nyalldawson May 2, 2024
9294023
Add text format conversion
nyalldawson May 3, 2024
0034f13
Start on label settings conversion
nyalldawson May 3, 2024
8c4307f
Add note
nyalldawson May 3, 2024
f3aea19
Convert label zoom range
nyalldawson May 3, 2024
b4f8095
Use v2 API for uploading layers
nyalldawson May 3, 2024
4ea3a16
Attempt to patch layer style
nyalldawson May 3, 2024
2e51891
Fix patch data
nyalldawson May 3, 2024
f1cbee9
s/category/categorical
nyalldawson May 3, 2024
8586dc2
Support labels
nyalldawson May 3, 2024
f3e78ab
labelAttribute should be an array
nyalldawson May 9, 2024
1f31a5b
Skip test on older qgis
nyalldawson May 9, 2024
dbb48e3
Skip other test on old qgis
nyalldawson May 9, 2024
3414038
Lint
nyalldawson May 9, 2024
6929ee9
Lint
nyalldawson May 9, 2024
7115ebb
Handle hairline stroke sizes
nyalldawson May 9, 2024
3a9e6db
Fix oversized point markers
nyalldawson May 9, 2024
1d369c6
Convert scale based visibility
nyalldawson May 9, 2024
9eba830
Lint
nyalldawson May 9, 2024
6161f9d
Convert simple rule based renderer setups
nyalldawson May 9, 2024
6efa17d
Lint
nyalldawson May 9, 2024
b6a7dbb
Start on raster style conversion
nyalldawson May 9, 2024
f824102
Try to upload converted psuedo color raster styling
nyalldawson May 9, 2024
ff3ee37
Fix conversion of fills with no fill color but stroke
nyalldawson May 10, 2024
27fad09
Hide upload as styled action
nyalldawson May 10, 2024
75fe2fb
Convert paletted raster renderer
nyalldawson May 10, 2024
a104c1d
Paletted should use categorical type
nyalldawson May 10, 2024
053f693
Tweak categorial raster fsl
nyalldawson May 10, 2024
95aec15
Short term workaround to get paletted uploads working
nyalldawson May 13, 2024
88523f5
Fix uploading styled rasters which cannot be converted to fsl
nyalldawson May 13, 2024
4ae83a6
Update tests
nyalldawson May 13, 2024
1b069c3
Lint
nyalldawson May 13, 2024
ddee6ed
Remove extraneous content from headers
nyalldawson May 13, 2024
8eee8de
Remove unused import
nyalldawson May 13, 2024
fce87ff
Update tests
nyalldawson May 13, 2024
958d2a6
Handle singleband gray renderer
nyalldawson May 13, 2024
aa56c82
Lint
nyalldawson May 13, 2024
d2bbb08
Fix exception when labels can be converted but not renderer
nyalldawson May 15, 2024
3f1dba5
Don't endless loop when rate limit is triggered
nyalldawson May 15, 2024
0c75f63
Fix stroke showing for categorized fills when it should be transparent
nyalldawson May 15, 2024
c80f18f
Convert qgis raster resampling setting
nyalldawson May 15, 2024
04bb182
Lint
nyalldawson May 15, 2024
0b19bd3
Lint
nyalldawson May 15, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Handle singleband gray renderer
nyalldawson committed May 13, 2024

Verified

This commit was signed with the committer’s verified signature.
nyalldawson Nyall Dawson
commit 958d2a6517898826cf7b83053a8bfb0105c5d174
41 changes: 40 additions & 1 deletion felt/core/fsl_converter.py
Original file line number Diff line number Diff line change
@@ -59,7 +59,8 @@
QgsExpressionContext,
QgsRasterRenderer,
QgsSingleBandPseudoColorRenderer,
QgsPalettedRasterRenderer
QgsPalettedRasterRenderer,
QgsSingleBandGrayRenderer
)

from .map_utils import MapUtils
@@ -1553,6 +1554,10 @@ def raster_renderer_to_fsl(
return FslConverter.singleband_pseudocolor_renderer_to_fsl(
renderer, context, opacity
)
if isinstance(renderer, QgsSingleBandGrayRenderer):
return FslConverter.singleband_gray_renderer_to_fsl(
renderer, context, opacity
)
if isinstance(renderer, QgsPalettedRasterRenderer):
return FslConverter.paletted_renderer_to_fsl(
renderer, context, opacity
@@ -1599,6 +1604,40 @@ def singleband_pseudocolor_renderer_to_fsl(
"type": "numeric"
}

@staticmethod
def singleband_gray_renderer_to_fsl(
renderer: QgsSingleBandGrayRenderer,
context: ConversionContext,
opacity: float = 1
) -> Optional[Dict[str, object]]:
"""
Converts a singleband gray renderer to FSL
"""
steps = [renderer.contrastEnhancement().minimumValue(),
renderer.contrastEnhancement().maximumValue()]
if renderer.gradient() == QgsSingleBandGrayRenderer.Gradient.BlackToWhite:
colors = ["rgb(0, 0, 0)", "rgb(255, 255, 255)"]
else:
colors = ["rgb(255, 255, 255)", "rgb(0, 0, 0)"]

return {
"config": {
"band": renderer.grayBand(),
"steps": steps
},
"legend": {
"displayName": {"0": str(steps[0]),
"1": str(steps[1])}
},

"style": {
"isSandwiched": False,
"opacity": opacity,
"color": colors
},
"type": "numeric"
}

@staticmethod
def paletted_renderer_to_fsl(
renderer: QgsPalettedRasterRenderer,
39 changes: 38 additions & 1 deletion felt/test/test_fsl_conversion.py
Original file line number Diff line number Diff line change
@@ -50,7 +50,9 @@
QgsRasterShader,
QgsColorRampShader,
QgsGradientColorRamp,
QgsPalettedRasterRenderer
QgsPalettedRasterRenderer,
QgsSingleBandGrayRenderer,
QgsContrastEnhancement
)

from .utilities import get_qgis_app
@@ -1997,6 +1999,41 @@ def test_convert_singleband_pseudocolor(self):
'type': 'numeric'}
)

def test_convert_singleband_gray_renderer(self):
"""
Convert singleband gray renderer
"""
context = ConversionContext()
renderer = QgsSingleBandGrayRenderer(None, 1)
enhancement = QgsContrastEnhancement()
enhancement.setMinimumValue(5)
enhancement.setMaximumValue(5)
renderer.setContrastEnhancement(QgsContrastEnhancement(enhancement))

self.assertEqual(FslConverter.raster_renderer_to_fsl(
renderer, context),
{'config': {'band': 1, 'steps': [5.0, 5.0]},
'legend': {'displayName': {'0': '5.0', '1': '5.0'}},
'style': {'color': ['rgb(0, 0, 0)', 'rgb(255, 255, 255)'],
'isSandwiched': False,
'opacity': 1},
'type': 'numeric'}
)

renderer = QgsSingleBandGrayRenderer(None, 2)
renderer.setGradient(QgsSingleBandGrayRenderer.Gradient.WhiteToBlack)
renderer.setContrastEnhancement(QgsContrastEnhancement(enhancement))

self.assertEqual(FslConverter.raster_renderer_to_fsl(
renderer, context),
{'config': {'band': 2, 'steps': [5.0, 5.0]},
'legend': {'displayName': {'0': '5.0', '1': '5.0'}},
'style': {'color': ['rgb(255, 255, 255)', 'rgb(0, 0, 0)'],
'isSandwiched': False,
'opacity': 1},
'type': 'numeric'}
)

@unittest.skip('Broken API, disabled for now')
def test_convert_paletted_raster(self):
"""