mirror of
				https://github.com/qgis/QGIS.git
				synced 2025-10-24 00:04:44 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			63 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # -*- coding: utf-8 -*-
 | |
| 
 | |
| """
 | |
| ***************************************************************************
 | |
|     v_proj.py
 | |
|     ---------
 | |
|     Date                 : November 2017
 | |
|     Copyright            : (C) 2017 by Médéric Ribreux
 | |
|     Email                : medspx at medspx dot fr
 | |
| ***************************************************************************
 | |
| *                                                                         *
 | |
| *   This program is free software; you can redistribute it and/or modify  *
 | |
| *   it under the terms of the GNU General Public License as published by  *
 | |
| *   the Free Software Foundation; either version 2 of the License, or     *
 | |
| *   (at your option) any later version.                                   *
 | |
| *                                                                         *
 | |
| ***************************************************************************
 | |
| """
 | |
| 
 | |
| __author__ = 'Médéric Ribreux'
 | |
| __date__ = 'November 2017'
 | |
| __copyright__ = '(C) 2017, Médéric Ribreux'
 | |
| 
 | |
| from qgis.core import QgsProcessingParameterString
 | |
| 
 | |
| 
 | |
| def processInputs(alg, parameters, context, feedback):
 | |
|     # Grab the projection from the input vector layer
 | |
|     layer = alg.parameterAsLayer(parameters, 'input', context)
 | |
|     alg.setSessionProjectionFromLayer(layer)
 | |
|     layerCrs = layer.crs().toProj()
 | |
| 
 | |
|     # Creates a new location with this Crs
 | |
|     newLocation = 'newProj{}'.format(alg.uniqueSuffix)
 | |
|     alg.commands.append('g.proj proj4="{}" location={}'.format(
 | |
|         layerCrs, newLocation))
 | |
| 
 | |
|     # Go to the newly created location
 | |
|     alg.commands.append('g.mapset mapset=PERMANENT location={}'.format(
 | |
|         newLocation))
 | |
| 
 | |
|     # Import the layer
 | |
|     alg.loadVectorLayerFromParameter(
 | |
|         'input', parameters, context, feedback, False)
 | |
| 
 | |
|     # Go back to default location
 | |
|     alg.commands.append('g.mapset mapset=PERMANENT location=temp_location')
 | |
| 
 | |
|     # Grab the projected Crs
 | |
|     crs = alg.parameterAsCrs(parameters, 'crs', context)
 | |
|     alg.commands.append('g.proj -c proj4="{}"'.format(crs.toProj()))
 | |
| 
 | |
|     # Remove crs parameter
 | |
|     alg.removeParameter('crs')
 | |
| 
 | |
|     # Add the location parameter with proper value
 | |
|     location = QgsProcessingParameterString(
 | |
|         'location',
 | |
|         'new location',
 | |
|         'newProj{}'.format(alg.uniqueSuffix)
 | |
|     )
 | |
|     alg.addParameter(location)
 |