當前位置: 首頁>>代碼示例>>Python>>正文


Python core.QgsRectangle方法代碼示例

本文整理匯總了Python中qgis.core.QgsRectangle方法的典型用法代碼示例。如果您正苦於以下問題:Python core.QgsRectangle方法的具體用法?Python core.QgsRectangle怎麽用?Python core.QgsRectangle使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在qgis.core的用法示例。


在下文中一共展示了core.QgsRectangle方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: zoomTo

# 需要導入模塊: from qgis import core [as 別名]
# 或者: from qgis.core import QgsRectangle [as 別名]
def zoomTo(self, srcCrs, lat, lon):
        canvasCrs = self.canvas.mapSettings().destinationCrs()
        transform = QgsCoordinateTransform(srcCrs, canvasCrs, QgsProject.instance())
        x, y = transform.transform(float(lon), float(lat))

        rect = QgsRectangle(x, y, x, y)
        self.canvas.setExtent(rect)

        pt = QgsPointXY(x, y)
        self.highlight(pt)
        self.canvas.refresh()
        return pt 
開發者ID:NationalSecurityAgency,項目名稱:qgis-latlontools-plugin,代碼行數:14,代碼來源:latLonTools.py

示例2: test_copy

# 需要導入模塊: from qgis import core [as 別名]
# 或者: from qgis.core import QgsRectangle [as 別名]
def test_copy(self):
        source_folder = tempfile.mkdtemp()
        export_folder = tempfile.mkdtemp()
        shutil.copytree(os.path.join(test_data_folder(), 'simple_project'), os.path.join(source_folder,
                                                                                         'simple_project'))

        project = self.load_project(os.path.join(source_folder, 'simple_project', 'project.qgs'))
        extent = QgsRectangle()
        offline_editing = QgsOfflineEditing()
        offline_converter = OfflineConverter(project, export_folder, extent, offline_editing)
        offline_converter.convert()

        files = os.listdir(export_folder)

        self.assertIn('project_qfield.qgs', files)
        self.assertIn('france_parts_shape.shp', files)
        self.assertIn('france_parts_shape.dbf', files)
        self.assertIn('curved_polys.gpkg', files)
        self.assertIn('spatialite.db', files)

        dcim_folder = os.path.join(export_folder, "DCIM")
        dcim_files = os.listdir(dcim_folder)
        self.assertIn('qfield-photo_1.jpg', dcim_files)
        self.assertIn('qfield-photo_2.jpg', dcim_files)
        self.assertIn('qfield-photo_3.jpg', dcim_files)
        dcim_subfolder = os.path.join(dcim_folder, "subfolder")
        dcim_subfiles = os.listdir(dcim_subfolder)
        self.assertIn('qfield-photo_sub_1.jpg', dcim_subfiles)
        self.assertIn('qfield-photo_sub_2.jpg', dcim_subfiles)
        self.assertIn('qfield-photo_sub_3.jpg', dcim_subfiles)

        shutil.rmtree(export_folder)
        shutil.rmtree(source_folder) 
開發者ID:opengisch,項目名稱:qfieldsync,代碼行數:35,代碼來源:test_export.py

示例3: set_layer_extent

# 需要導入模塊: from qgis import core [as 別名]
# 或者: from qgis.core import QgsRectangle [as 別名]
def set_layer_extent(map_canvas, gpx_layer):
    """
    Sets the layer extent and zooms in to 1:1 scale
    :param gpx_layer: GPX layer object
    :param map_canvas: Map canvas object
    :return: None
    :rtype: None
    """
    x_min, x_max, y_min, y_max = gpx_layer.GetExtent()
    extent = q_core.QgsRectangle(x_min, y_min, x_max, y_max)
    extent.scale(1.1)
    map_canvas.setExtent(extent)
    map_canvas.refresh() 
開發者ID:gltn,項目名稱:stdm,代碼行數:15,代碼來源:gps_tool_data_view_utils.py

示例4: centerObject

# 需要導入模塊: from qgis import core [as 別名]
# 或者: from qgis.core import QgsRectangle [as 別名]
def centerObject(feature, zoom=None):
    """
        Centers the map view on a given object.

        https://developers.google.com/earth-engine/api_docs#map.centerobject

        Uses:
            >>> from ee_plugin import Map
            >>> Map.centerObject(feature)
    """


    feature = ee.Feature(feature)

    if not zoom:
        # make sure our geometry is in geo
        rect = feature.geometry().transform(ee.Projection('EPSG:4326'), 1)

        # get coordinates
        coords = rect.bounds().getInfo()['coordinates'][0]
        xmin = coords[0][0]
        ymin = coords[0][1]
        xmax = coords[2][0]
        ymax = coords[2][1]

        # construct QGIS geometry
        rect = QgsRectangle(xmin, ymin, xmax, ymax)

        # transform rect to a crs used by current project
        crs_src = QgsCoordinateReferenceSystem(4326)
        crs_dst = QgsCoordinateReferenceSystem(QgsProject.instance().crs())
        geo2proj = QgsCoordinateTransform(crs_src, crs_dst, QgsProject.instance())
        rect_proj = geo2proj.transform(rect)

        # center geometry
        iface.mapCanvas().zoomToFeatureExtent(rect_proj)
    else:
        # set map center to feature centroid at a specified zoom
        center = feature.geometry().centroid().coordinates().getInfo()
        setCenter(center[0], center[1], zoom) 
開發者ID:gee-community,項目名稱:qgis-earthengine-plugin,代碼行數:42,代碼來源:Map.py

示例5: geom_to_geo

# 需要導入模塊: from qgis import core [as 別名]
# 或者: from qgis.core import QgsRectangle [as 別名]
def geom_to_geo(geom):
    crs_src = QgsCoordinateReferenceSystem(QgsProject.instance().crs())
    crs_dst = QgsCoordinateReferenceSystem(4326)
    proj2geo = QgsCoordinateTransform(crs_src, crs_dst, QgsProject.instance())

    if isinstance(geom, QgsPointXY):
        return proj2geo.transform(geom)
    elif isinstance(geom, QgsRectangle):
        return proj2geo.transformBoundingBox(geom)
    else:
        return geom.transform(proj2geo) 
開發者ID:gee-community,項目名稱:qgis-earthengine-plugin,代碼行數:13,代碼來源:utils.py

示例6: center_to_point

# 需要導入模塊: from qgis import core [as 別名]
# 或者: from qgis.core import QgsRectangle [as 別名]
def center_to_point(self, point):
        canvas = self.iface.mapCanvas()
        new_extent = QgsRectangle(canvas.extent())
        new_extent.scale(1, point)
        canvas.setExtent(new_extent)
        canvas.refresh() 
開發者ID:nextgis,項目名稱:quickmapservices,代碼行數:8,代碼來源:rb_result_renderer.py

示例7: toQgsRectangle

# 需要導入模塊: from qgis import core [as 別名]
# 或者: from qgis.core import QgsRectangle [as 別名]
def toQgsRectangle(self):
        return QgsRectangle(self.xmin, self.ymin, self.xmax, self.ymax) 
開發者ID:nextgis,項目名稱:quickmapservices,代碼行數:4,代碼來源:tiles.py

示例8: extent

# 需要導入模塊: from qgis import core [as 別名]
# 或者: from qgis.core import QgsRectangle [as 別名]
def extent(self):
        size = self.tsize1 / 2 ** (self.zoom - 1)
        if self.serviceInfo.tile_ranges is None:
            return QgsRectangle(self.xmin * size - self.tsize1, self.tsize1 - (self.ymax + 1) * size,
                                (self.xmax + 1) * size - self.tsize1, self.tsize1 - self.ymin * size)
        else:
            originX = self.serviceInfo.originX
            originY = self.serviceInfo.originY
            return QgsRectangle(originX + self.xmin * size, originY - (self.ymax + 1) * size,
                                originX + (self.xmax + 1) * size, originY - self.ymin * size) 
開發者ID:nextgis,項目名稱:quickmapservices,代碼行數:12,代碼來源:tiles.py

示例9: getTileRect

# 需要導入模塊: from qgis import core [as 別名]
# 或者: from qgis.core import QgsRectangle [as 別名]
def getTileRect(self, zoom, x, y):
        size = self.tsize1 / 2 ** (zoom - 1)
        return QgsRectangle(x * size - self.tsize1, self.tsize1 - y * size, (x + 1) * size - self.tsize1,
                            self.tsize1 - (y + 1) * size) 
開發者ID:nextgis,項目名稱:quickmapservices,代碼行數:6,代碼來源:tiles.py

示例10: on_zoomButton_clicked

# 需要導入模塊: from qgis import core [as 別名]
# 或者: from qgis.core import QgsRectangle [as 別名]
def on_zoomButton_clicked(self):
        """
        Slot used to zoom the mapcanvas to the features associated to a complex
        """
        #case no item is selected we should warn the user
        if len(self.treeWidget.selectedItems()) == 0:
            QMessageBox.warning(self.iface.mainWindow(), self.tr("Warning!"), self.tr("Please, select an item to zoom."))
            return

        item = self.treeWidget.selectedItems()[0]
        #checking if the item is a complex (it should have depth = 2)
        if self.depth(item) == 2:
            bbox = QgsRectangle()
            for i in range(item.childCount()):
                aggregated_item = item.child(i)
                aggregated_class = aggregated_item.text(0)
                #getting the layer the needs to be updated
                aggregated_layer = None
                layers = self.iface.mapCanvas().layers()
                for layer in layers:
                    if layer.name() == aggregated_class:
                        aggregated_layer = layer
                        break

                if not aggregated_layer:
                    QMessageBox.warning(self.iface.mainWindow(), self.tr("Warning!"), self.tr("The associated classes must be loaded in the table of contents."))
                    return

                for j in range(aggregated_item.childCount()):
                    id = aggregated_item.child(j).text(0)
                    freq = QgsFeatureRequest()
                    freq.setFilterFid(int(id))
                    feature = next(layer.getFeatures( freq ))
                    if j==0 and i == 0:
                        bbox=feature.geometry().boundingBox()
                    bbox.combineExtentWith(feature.geometry().boundingBox())

            self.iface.mapCanvas().setExtent(bbox)
            self.iface.mapCanvas().refresh()
        else:
            QMessageBox.warning(self.iface.mainWindow(), self.tr("Warning!"), self.tr("Select a complex."))
            return 
開發者ID:dsgoficial,項目名稱:DsgTools,代碼行數:44,代碼來源:complexWindow.py


注:本文中的qgis.core.QgsRectangle方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。