Data lansării: 2018-02-23
Cea mai bună versiune de QGIS! QGIS 3.0 constituie o revizuire din temelii a îndrăgitului nostru soft de GIS cu sursă deschisă. QGIS 3.0 aduce o listă masivă de modificări - pe cele mai importante încercând să le expunem aici. Ca întotdeauna, vă reamintim că proiectul QGIS este open source, de aceea, dacă vă permiteți, puteți lua în considerare susținerea activității noastre prin intermediul unor donații, sponsorizări sau contribuții la documentația codului, a site-ului web și așa mai departe.
Mulțumiri
Dorim să mulțumim dezvoltatorilor, creatorilor documentației, testerilor și voluntarilor pentru timpul dedicat și pentru efortul depus (sau pentru că au finanțat anumite persoane în scopurile enumerate). Din partea comunității QGIS, sperăm să vă bucurați de această versiune! Dacă doriți să contribuiți cu efort, bani, sau să vă implicați într-un mod care ar putea îmbunătăți QGIS, vă rugăm să vizitați qgis.org și să oferiți o mână de ajutor!
QGIS este susținut din donații și sponsorizări. Listă curentă a celor care au efectuat contribuții financiare mari și mici la proiect poate fi consultată aici. Dacă doriți să deveniți un sponsor oficial al proiectului, vă rugăm să vizitați pagina sponsorizărilor pentru detalii. Sponsorizările QGIS ne ajută să finanțăm întâlnirea dezvoltatorilor o dată la șase luni, să menținem infrastructura proiectului și să finanțăm eforturile de eliminare a erorilor. În continuare este prezentată lista completă a sponsorilor actuali - acestora le transmitem mulțumirile noastre!
QGIS este un soft gratuit iar dvs. nu aveți obligația de a plăti pentru folosirea lui - de fapt, vrem să încurajăm oamenii de oriunde să-l folosească, indiferent de starea financiară sau socială - având convingerea că, punerea la dispoziția utilizatorilor a posibilităților de decizie spațială, va duce la o societate mai bună pentru întreaga omenire.
Funcționalitate: S-a eliminat plugin-ul de statistici zonale
Funcționalitate: S-a eliminat plugin-ul de conversie dxf2shp
Funcționalitate: S-a eliminat furnizorul TauDEM din nucleul Processing
Funcționalitate: Controalele grafice Photo, WebView și FileName au fost preluate de Atașament
Funcționalitate: Furnizorii otb și lidartools au fost eliminați din Processing
Feature: save and restore color ramp used for singleband pseudocolor rendering
Feature: Support setting of color and transparency on multiple items for raster renderers
Feature: Show an alpha slider in color button drop down menu
Feature: Raster stretch toolbar actions support for pseudocolor renderer
Formulare și Controale grafice
Funcționalitate: Este permis controlul etichetelor pentru controale grafice de editare
Feature: Allow configuring link/unlink feature buttons on relation editor widget
Feature: Smarter default edit widgets with plugins to pick them
Feature: Show field values in autocompleter in form filter mode
Feature: Add zoom to features and flash features shortcuts in select by form dialog
Feature: Add between/not between to numerical fields in select by form
Feature: Support all GDAL writable raster formats for «Save as» dialog on raster layers
Feature: Support for Z/M geometries in gpkg, spatialite and memory layer provider
Feature: Detect literal default values for spatialite provider
Feature: Create attribute index support for spatialite provider
Feature: Load/save style in database for GPKG and Spatialite
Land Vorarlberg |
Grupul utilizatorilor Elvețieni de QGIS |
AERO ASAHI Corporation |
Grupul utilizatorilor Danezi de QGIS |
ARTOGIS a/s |
Grupul utilizatorilor Germani de QGIS |
OPENGIS.ch GmbH |
Terraplan |
Biroul Lucrărilor Publice, Secția de Gestionare a Datelor și a Riscurilor de Inundații |
WIGeoGIS |
2D3D.GIS |
Integrate Sustainability Pty Ltd |
Ager Technology |
LandPlan OS GmbH |
Alta ehf |
Lutra Consulting |
Asociación Geoinnova |
MHTC Ltd |
Automatic Knowledge |
MappingGIS |
BGEO Open GIS, SL |
Mapzen |
Cawdor Forestry |
Mierune LLC |
Chartwell Consultants Ltd. |
OSGeo.JP |
City of Canning |
Open Geo Groep |
City of Canning |
Pixalytics |
Datenbankgesellschaft mbH |
Grupul utilizatorilor Brazilieni de QGIS |
Dr. Kerth + Lampe Geo-Infometric GmbH |
Grupul utilizatorilor Suedezi de QGIS |
FORNAT AG |
QTibia Engineering |
Forest Design SRL |
Royal Borough of Windsor and Maidenhead |
GAIA mbH |
|SOLTIG (Soluții pentru Tehnologia Informațiilor Geografice)| SOLTIG (Soluții pentru Tehnologia Informațiilor Geografice) |
GIS Support Sp. z o.o. |
Septima |
GKG Kassel, (Dr.-Ing. Claas Leiner) |
Solargis s.r.o. |
Gaia3D, Inc. |
Syddjurs Kommune |
Gemeente Gouda |
TerreLogiche |
GeoS Geodätische Software Andreas Hellinge |
Trage Wegen vzw |
Geographica |
Urbsol |
Gis3W |
WAGNER-IT |
Infraplan Engineering Services Pvt. Ltd. |
WhereGroup GmbH & Co. KG |
Ingenieurbüro Kauppert |
tkt teleconsult Kommunikationstechnik GmbH |
Insurance Australia Group Limited (IAG) |
De acum, statisticile zonale sunt posibile prin intermediul Processing, acesta find locul logic al acestei funcționalități.
Această funcție este disponibilă în OGR, nemaifiind nevoie în QGIS de un plugin special dedicat acestei sarcini
TauDEM este un set de instrumente specializate, care necesită instalarea unor instrumente suplimentare. Ca atare, am decis să îl transformăm într-un furnizor separat, reducând mărimea codului de bază și eforturile de întreținere.
S-au adăugat noi butoane de ajutor pentru algoritmi și dialoguri, iar multe dintre acestea dirijează utilizatorul înspre documentația QGIS online.
Este posibilă configurarea accesării ajutorului contextual: din internet, din rețeaua organizației sau de pe computerul local. De asemenea, este posibilă combinarea diverselor surse de ajutor.
Această funcționalitate a fost dezvoltată de Alexander Bruy
The new logic will be to develop plugin providers that will be able to follow the external software lifecycle.
For qt > 5.6 builds, it is possible to drop several floating docks in the same floating window where they appear as tabs https://woboq.com/blog/qdockwidget-changes-in-56.html
Some mouse / pointer devices (notably on mac) have finer resolutions. They send mouse wheel events at a high frequency but with smaller delta values. Zooming with such devices was unusable for fast zoom actions. This has been fixed in 3.0.
Această funcționalitate a fost dezvoltată de Matthias Kuhn
Supports search by action name and by shortcut
Această funcționalitate a fost dezvoltată de Alexander Bruy
The Locator bar is a fast, always ready, generic and pluggable search facility in the Left Bottom corner of QGIS.
Currently it is able to search for algorithms, actions and layer names, but also to select a feature in current active layer by typing an attribute value.
It is «easy» extendable, so everybody can create a QgsLocatorFilter for his/her national geocoding service or other search online or database search facility.
Această funcționalitate a fost dezvoltată de Nyall Dawson
map unit scaling
color brewer and limited random ramp editors
editing colors in a color list inline in the style panel
inline editing of colors and symbols in composer
now shown inline in style panel
Color setting has been added for all map canvas north arrow decoration.
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
The map canvas» save as image function has been expanded and now offers users the possibility to tweak the scale, resolution, and extent on-the-fly. Extents can be restricted to a height-width ratio. A save as PDF function was also added to quickly export the map canvas into a resolution-independent PDF.
Această facilitate a fost finanțată de Andreas Neumann (finanțare parțială)
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
Accesibil via: - Vizualizare meniu > Inversare Vizibilitate Panouri - combinația de taste Ctrl+Tab
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
This work sponsored by the QGIS grant program on „adding consistency to UI controls” is now complete and merged into master. The following tasks were done as part of this work:
All API regarding transparency/opacity/alpha was standardised to setOpacity() and opacity(). The methods take a double value between 0 (transparent) and 1 (opaque), keeping consistency with the Qt API.
A new widget QgsOpacityWidget was created, and is now used everywhere through the UI where opacity is set. This ensures consistent behavior and look for opacity controls everywhere.
Rotation has been standardised in the API and UI, so now rotation is always applied clockwise. All rotation widgets have been updated so they accept values from -360 to 360.
2.x Projects with labeling using rotation and data defined rotation are transparently upgraded upon opening in 3.0
Scale APIs have been made consistent throughout the QGIS API. The confusing mix of scale denominators vs real scales has been removed, with everything now operating on scale denominators. The behaviour of all scale range calls is standardised with a common meaning for min/max scales (and explicit api documentation regarding this)
All scale controls now use the standard scale widgets for consistency across the UI
Labeling now uses the same definition for min/max scale as the rest of the UI, and existing projects are transparently upgraded on opening in 3.0.
Fixed most outstanding bugs relating to scale usage, including bugs breaking the rule based scale limits
Thanks to the QGIS PSC and project donors for sponsoring this work and allowing it to proceed!
Această facilitate a fost finanțată cu ajutorul Sponsorizărilor și Donațiilor QGIS
Această funcționalitate a fost dezvoltată de Nyall Dawson
If you try to open many sublayers, you can now open them all within a same group in the legend.
**Această funcționalitate a fost finanțată de Kartoza
Această funcționalitate a fost dezvoltată de Etienne Trimaille
We have a brand new native 3D map view in QGIS! The 3D map view displays 2D map (rendered from project layers) on top terrain. By default the terrain is a flat plane, but it is possible to use raster layers with digital elevation model as the source of height data.
Use menu View > New 3D Map View to add a 3D view of the project. This will create a new dock widget with 3D map canvas. The 3D view uses the same controls like 2D map views to browse the map using mouse (drag map to move it around, mouse wheel to zoom) or keyboard arrow keys. In addition there are camera controls specific to 3D views: it is possible to rotate and tilt camera by one of the following ways:
by dragging the mouse with middle mouse button pressed
by pressing Shift and dragging the mouse with left mouse button pressed
by pressing Shift and using up/down/left/right keys
Această funcționalitate a fost finanțată de QGIS.ORG
Această funcționalitate a fost dezvoltată de Martin Dobias (Lutra Consulting)
In the default configuration, map layers are rendered into 2D map images on top of the terrain. It is however possible to make better use of the 3D world by configuring 3D renderers for some map layers. With 3D renderers, the data can be displayed in 3D views as true 3D objects - this is currently supported for vector layers (all geometry types - point, line or polygon). This enables much better visualization, for example:
polygons with building footprints may be extruded (possibly with data-defined height) to achieve 3D look
points with tree point locations can be rendered with 3D symbols of trees (simple geometric shapes or existing 3D models loaded from a supported file format)
To configure 3D renderers, use layer styling dock widget or the vector layer properties dialog - there is a new tab for configuration of 3D renderers.
Această funcționalitate a fost finanțată de QGIS.ORG
Această funcționalitate a fost dezvoltată de Martin Dobias, Peter Petrik (Lutra Consulting)
Adds @project_crs
and @project_crs_definition
variables for retrieving the current project CRS
Returns current locale used by QGIS. By default this is current system locale. If user enabled locale override in QGIS settings overriden locale will be returned.
Această funcționalitate a fost dezvoltată de Alexander Bruy
- map_crs, map_crs_definition: retrieves crs details for map
- map_units: retrieves units for map (eg 'meters','degrees')
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Atlas expressions
atlas_layerid and atlas_layername: Returnează ID-ul și numele stratului curent din atlas.
Expresii agregate
array_agg(expression, group_by, filter): Returnează o matrice de valori agregate, dintr-un câmp sau dintr-o expresie.
Array expressions
New group that contains expression functions for the creation and manipulation of arrays (also known as list data structures). The order of values within the array matters, in contrary to the «map» data structure, where the order of key-value pairs is irrelevant and values are identified by their keys.
array(value1, value2, …) : Returnează o matrice care conține toate valorile transmise ca parametru.
array_append(array, value): Returnează o matrice la sfârșitul căreia se va adăuga valoarea dată.
array_cat(array1, array2, …): Returnează o matrice în care sunt concatenate toate matricile transmise.
array_contains(array, value): Returnează true dacă o matrice conține valoarea dată.
array_distinct(array): Returnează o matrice care conține valori distincte ale șirului dat.
array_find(array, value): Returnează indicele (0 pentru primul) pentru valoarea din cadrul unei matrici. Returnează -1 dacă valoarea nu a fost găsită.
array_first(array): Returnează prima valoare a unei matrici.
array_get(array, index): Returnează valoarea a N-a (0 pentru prima) dintr-o matrice.
array_insert(array, pos, value): Returnează o matrice căreia i se va adăuga o valoare în poziția dată.
array_intersect(array1, array2): Returnează true dacă orice element al matricei1 există în matricea2.
array_last(array): Returnează ultima valoare a unei matrici.
array_length(array): Returnează numărul de elemente al unei matrici.
array_prepend(array, value): Returnează o matrice la începutul căreia se va adăuga valoarea dată.
array_remove_all(array, value): Returnează o matrice din care sunt eliminate intrările care conțin valoarea dată.
array_remove_at(array, pos): Returnează o matrice din care este eliminat indicele dat.
array_reverse(array): Returnează o matrice dată, având inversată ordinea valorilor
array_slice(array, start_pos, end_pos): Returnează o parte a matricei. Porțiunea este definită prin argumentele start_pos și end_pos.
array_to_string(array, delimiter, empty_value): Concatenează elementele matricei într-un șir de caractere separate printr-un delimitator, folosind pentru valorile vide șirul opțional.
regexp_matches(string, regex, empty_value): Returnează o matrice a tuturor șirurilor de caractere colectate de grupurile de capturare, în ordinea în care apar grupurile în expresia regulată aplicată asupra unui șir de caractere.
string_to_array(string, delimiter, empty_value): Fragmentează șirul într-o matrice, folosind delimitatorul furnizat, alături de șirul de caractere pentru valorile vide, opțional.
Color expressions
create_ramp(map, discrete): Returnează un interval cu gradienți dintr-o hartă de șiruri de caractere reprezentând trepte de culori.
Date and Time expressions
epoch(date): Returnează intervalul de la începerea erei unix și o anumită dată, în milisecunde.
Expresii Generale
env(name): Gets an environment variable and returns its content as a string. If the variable is not found, NULL will be returned.
raster_statistic(layer, band, property): Returnează statisticile dintr-un strat raster. Proprietăți: min/max/avg/range/stdev/sum
with_variable(name, value, node): Această funcție stabilește o variabilă pentru orice expresie de cod, care va fi furnizată ca al 3-lea argument. Acest lucru este util doar pentru expresiile complicate, unde aceeași valoare calculată trebuie să fie utilizată în diferite locuri.
Expresii geometrice
extend(geometry, start_distance, end_distance): Extends linestrings by a specified amount at the start and end of the line
hausdorff_distance(geometry a, geometry b, densify_fraction): Returns the Hausdorff distance between two geometries. This is basically a measure of how similar or dissimilar 2 geometries are, with a lower distance indicating more similar geometries.
inclination(inclination(point_a, point_b): Returnează înclinația, măsurată dinspre apogeu (0) înspre punctul diametral opus (180) de la point_a la point_b.
make_circle(center, radius, segment): Creează un poligon circular, segmentat.
make_ellipse(center, semi_major_axis, semi_minor_axis, azimuth, segment): Creează un poligon eliptic, segmentat.
make_regular_polygon(center, radius, number_sides, circle): Creează un poligon regulat, segmentat.
make_triangle(): documentația încă lipsește
minimal_circle(geometry, segment): Returnează cercul minim de includere a unei geometrii. Acesta reprezintă cercul minim care include toate geometriile din cadrul setului.
offset_curve(geometry, distance, segments, join, miter_limit): Returnează o geometrie formată prin decalarea unei geometrii de tip linie. Distanțele sunt în Sistemul de Referință Spațial al acestei geometrii.
oriented_bbox(geom): Returnează o geometrie care reprezintă caseta minimă de încadrare, orientată, a unei geometrii de intrare.
pole_of_inaccessibility(geometry, tolerance): Efectuează calculul aproximativ al polului inaccesibilității pentru o suprafață, adică punctul intern cel mai îndepărtat de limitele suprafeței. Această funcție utilizează algoritmul «polylabel» (Vladimir Agafonkin, 2016), care, printr-o abordare iterativă, garantează găsirea polului adevărat al inaccesibilității, în limitele unei toleranțe specificate.
simplify(geometry, tolerance): Simplifică o geometrie prin eliminarea nodurilor, folosind un prag bazat pe o distanță (de exemplu, algoritmul Douglas Peucker). Algoritmul păstrează devierile mari din geometrii și reduce numărul de vertexuri din segmentele aproape drepte.
simplify_vw(geometry, tolerance): Simplifică o geometrie prin eliminarea nodurilor, folosind un prag bazat pe o suprafață (cum ar fi algoritmul Visvalingam-Whyatt). Algoritmul elimină vertexurile care creează mici suprafețe în geometrii, cum ar fi vârfurile înguste sau segmentele aproape drepte.
smooth(geometry, iterations, offset, min_length, max_angle): Netezește o geometrie prin adăugarea de noduri suplimentare care rotunjesc colțurile din geometrie.
single_sided_buffer(geometry, distance, segments, join, miter_limit): Returnează o geometrie formată prin tamponarea unei singure părți a unei geometrii de tip linie. Distanțele sunt date în Sistemul de Referință Spațială al acestei geometrii.
Proprietăţile Stratului
crs_description returnează descrierea CRS-ului stratului.
Map Expressions
Acest grup conține funcții pentru crearea și manipularea structurilor de date tip «hartă» (cunoscute și ca obiecte dicționar, perechi cheie-valoare sau matrici asociative). Cheilor date li se pot asigna valori Ordinea perechilor cheie-valoare în obiectul hartă este irelevantă.
map(key1, value1, key2, value2, , …): Returnează o hartă care conține toate cheile și valorile transmise ca perechi de parametri.
map_akeys(map): Returnează, sub formă de matrice, toate cheile unei hărți.
map_avals(map): Returnează, sub formă de matrice, toate valorile unei hărți.
map_concat(map1, map2, …): Returnează o hartă care conține toate intrările hărților date. Dacă două hărți conțin aceeași cheie, se ia în considerare valoarea celei de a doua hărți.
map_delete(map, key): Returnează o hartă, folosind o anumită cheie și valoarea ștearsă, corespunzătoare acesteia.
map_exist(map, key): Returnează true dacă există o anumită cheie în hartă.
map_get(map, key): Returnează valoarea unei hărți, plecând de la cheia sa.
map_insert(map, key, value): Returnează o hartă cu o anumită cheie/valoare.
Straturile Hărții
New group that contains a list of map layers available in the current project. Returns internal map layer ids. This is used in many other expression functions that reference map layers.
Expresii matematice
inclination(point_a, point_b): Returnează înclinația, măsurată dinspre apogeu (0) înspre punctul diametral opus (180) de la point_a la point_b.
Operatori
~: Performs a regular expression match on a string value.
Record and Attributes Expressions
renamed from just „Record”
get_feature_by_id(layer, feature_id): Returnează entitatea cu id-ul specificat.
is_selected(feature, layer): Se returnează dacă este selectată o entitate. Dacă se apelează fără parametri, atunci va fi marcată entitatea curentă.
num_selected(layer): Returnează numărul de entități selectate într-un anumit strat. În mod implicit, operează asupra stratului pe care este evaluată expresia.
represent_value(value, fieldName): Returns the configured representafftion value for a field value. It depends on the configured widget type. Often, this is useful for «Value Map» widgets.
uuid(): Generează un Identificator Unic Universal (UUID) pentru fiecare rând care folosește metoda Qt QUuid::createUuid. Fiecare UUID are o lungime de 38 caractere.
Relații
New group listing all available table relations in a project. Useful for relation_aggregate functions.
Deprecated
$scale: old variable to get current map scale. Replaced by maps_scale
Modificări
Modificări în funcția substr()
support negative start value (e.g. substr(«hello»,-2) returns «lo»)
support negative length value (e.g. substr(«hello»,3,-1) returns «ll»)
length parameter now optional, defaults to end of string (e.g. substr(«hello world»,7) returns «world»)
strpos() now relies on a simple string within a string search
regexp_match() now returns pos of a matching regular expression
Această funcționalitate a fost construită de numeroși dezvoltatori
This makes it possible to access attributes and geometry from the parent feature when in the filter of the „aggregate” expression function. With this in place aggregates can be calculated per feature.
E.g. max "measurement" for each point_station per polygon_research_area.
Or a default attribute value when digitizing features:
aggregate(layer:='countries', aggregate:='max', expression:=\"code\", filter:=intersects( $geometry, geometry(@parent) ) )
Această funcționalitate a fost dezvoltată de Matthias Kuhn (OPENGIS.ch)
This adds a new item_variables expression function when expressions are used inside a composition context.
The function takes a single argument, the id for an item inside the composition, and returns a map of variable name to value for that item. This allows you to do things like insert text in a label fetching properties of another item in the composition, eg
Insert scale of map into a label:
map_get( item_variables( 'map'),'map_scale')
Insert x coordinate of map center into a label:
x(map_get( item_variables( 'map'),'map_extent_center'))
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Processing algorithms have been reviewed and documented. Clicking the Help button will open the QGIS website and show the algorithm description with enhanced documentation and pictures.
Această facilitate a fost finanțată prin Programul de Granturi QGIS
Această funcționalitate a fost dezvoltată de Matteo Ghetta (Faunalia), Alexander Bruy
Adds a data defined override to control a symbol layer’s visibility. Allows users to disable drawing certain symbol layers for matching features.
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Această funcționalitate a fost dezvoltată de Alexander Bruy
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Style management has received a major upgrade. The improvements include:
A new favorite grouping system was added, which the symbols list widget defaults to
The selected tag / smartgroup in the symbols list widget now persists when switching layers (and across sessions)
The symbols list widget will update the tag / smartgroup combo box when users add / rename / remove categories
Users can now directly tag, as well as add to favorites, symbols while saving those to the style database
To streamline style management, groups have been removed and fully replaced by tags
Tags have been integrated into the import/export user interface
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
It is now possible to change the color and transparency for multiple values at the same time for the singleband pseudocolor and the paletted renderers. Simply select values within the values» list and right click to have a pop-up menu appear.
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
In QGIS 3.0, it is now possible to change the transparency value for unique values for the paletted renderer.
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
see https://lists.osgeo.org/pipermail/qgis-developer/2016-September/044393.html follow up to raster pseudocolor updated extent auto classification.
Această funcționalitate a fost dezvoltată de Even Rouault
Allows setting left/top/right/bottom margins for the contents within an annotation.
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
This changes the rendering of annotation frames to use QGIS» symbology engine, which means that all the existing fill styles can now be used to style annotation frames.
Also paint effects & data defined symbol parameters.
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
New symbol renderer that groups nearby points into a single rendered marker symbol. Optionally, a label displays the number of features that have been aggregated into the single symbol.
Additionally, some improvements have been made to the point displacement renderer, specifically:
points are now assigned to the group which is „nearest” them, rather then just assigning them first group within the search distance. In some cases this was assigning features to a more distant cluster, resulting in less predictable cluster patterns
individual points are now correctly shown in their own selection state
lots of code cleanup + documentation too.
For developers: QgsPointDisplacementRenderer has been split into a new pure virtual QgsPointDistanceRenderer base class which handles the detection of clusters and grouping of points. The new cluster renderer reuses this base class to avoid code duplication.
See the crowd funding programme for more details.
Această funcționalitate a fost finanțată de Andreas Neumann, Qtibia Engineering (Tudor Barascu), Karl-Magnus Jönsson, Geonesia (Nicolas Ponzo) & numeroși susținători suplimentari anonimi, ale căror contribuții generoase sunt, de asemenea, foarte apreciate!
Această funcționalitate a fost dezvoltată de Nyall Dawson
vedeți http://nyalldawson.net/2017/02/new-map-coloring-algorithms-in-qgis-3-0/
Această funcționalitate a fost dezvoltată de Nyall Dawson
Allows use of a color ramp consisting of a list of selected colors. Currently there’s no way in QGIS to classify a renderer using some list of colors you’ve previously selected. So you can modify the colors manually after classifying, but that’s a pain if you’re regularly using the same color scheme. Basically, it’s like the color brewer color ramp options but allowing users to pick their own preset list of colors to use (Because Cynthia Brewer isn’t the only cartographic color expert!)
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Adds a new checkbox at the bottom of each symbol layer’s properties which allows you to control whether the layer is enabled or not. Disabled layers are not drawn, but are saved and can be enabled at a later stage. This makes it easier to tweak symbol appearance without having to totally delete a symbol layer.
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
In QGIS 3.0, the existing raster Paletted Renderer for rasters was adapted to allow for easy styling of discrete raster layers, such as landcover or boolean rasters. Now, users can select the renamed „Paletted/Unique Values” renderer and click the „Add Unique Values” button to load all unique raster values from the layer. These are automatically assigned a color using the selected color ramp.
The unique value calculation is performed in a background thread to keep the UI responsive for large (or remote) raster layers. Additionally, users can manually add individual new classes as desired, and edit the associated pixel value for any existing class. Deleting multiple classes at once is also supported, as well as changing the color, transparency and labels for multiple classes at once.
Color palettes can be loaded from a text file, with ESRI clr/GDAL/GRASS color table formats supported. Color palettes can be saved to a clr text file for sharing.
Această funcționalitate a fost finanțată de Stéphane Henriod, Satelligence (http://satelligence.com/), Bird’s Eye View (https://www.birdseyeviewgis.com/), alți susținători anonimi
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Thanks to the awesome auxiliary data storage and the editable joined table, the manual label customization is now always enabled. You do not need anymore to add dedicated fields in your datasource to change labels position, rotation, or any of the possible settings for labels to activate the toolbar. No more copy of readonly datasources and so much faster labeling ! Be warned, labels are only saved along with your project file in a .qgd sqlite database, or inside the .qgz zipped project file if you chose that format. Don’t forget to share that .qgd file if you want to share your project file.
And for power users, the old way of having data defined fields in your datasource is still there. Just define them in the layer’s properties as before!
Această funcționalitate a fost finanțată de Ministerul Francez de Ecologie, Dezvoltare Sustenabilă și Energie
Această funcționalitate a fost dezvoltată de OSLANDIA - Paul Blottiere
S-a adăugat suport pentru definirea cu ajutorul datelor a următoarelor proprietăți ale diagramelor:
Distanţă
Prioritate
ZIndex
IsObstacle
Show
AlwaysShow
Unghiul de Start al Diagramei
Această facilitate a fost finanțată prin Programul de Granturi QGIS
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
QGIS 3.0 now supports live layers. These layers get re-rendered automatically at a time interval that you determine, in a clean and flicker free way. Live layers are great for tracking continuously changing data like a fleet of cars, a flock of birds that you have telemetry data for and so on.
Această funcționalitate a fost dezvoltată de Kartoza & North Road
Following the live layer effects, this allows to trigger actions or layer refresh in QGIS only when the database notifies QGIS it should do something. It will require less ressources than refreshing on interval, and you can even code a chat application in QGIS with that :)
Vedeți https://vimeo.com/236604742
http://oslandia.com/en/2017/10/07/refresh-your-maps-from-postgresql/
Această funcționalitate a fost finanțată de Programul de Granturi QGIS
Această funcționalitate a fost dezvoltată de OSLANDIA - Vincent Mora
This change allows the labeling results to be cached to an image following a map render. If the cached label result image can be reused for the next render then it will be, avoiding the need to redraw all layers participating in the labeling problem and resolving the labeling solution. Basically this means that canvas refreshes as a result of changes to any NON-LABELED layer are much faster. (Changing a layer which is part of the labeling solution still requires all labeled layers to be completely redrawn)
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Grid renderer for points displacement
**Această funcționalitate a fost finanțată de Muhammad Yarjuna Rohmat (Kartoza)
That feature makes it possible to select a range of vertices from one feature.
It can be activated by pressing Shift+R - afterwards one needs to click start and final point within a feature - this will selected all vertices between the two.
The range selection can be cancelled anytime by right-click or by pressing Esc key.
For closed curves (polygons), it is possible to switch to the „longer” way around the ring by holding Ctrl while clicking the final point.
Această funcționalitate a fost finanțată de Ministerul francez responsabil de ecologie
Această funcționalitate a fost dezvoltată de Martin Dobias (Lutra Consulting)
Create Geopackages/Shapefiles: Now with the option to have Z-values
Această funcționalitate a fost dezvoltată de Alexander Lisovenko / Paul Blottiere
Just move a feature using the new „click - click ergonomy” and use the advanced digitizing panel and shortcut to constraint angles, distances, exact XY.
Această funcționalitate a fost dezvoltată de Denis Rouzaud
This allow to duplicate feature and move them in one move from a selected feature
Această funcționalitate a fost dezvoltată de Denis Rouzaud
You can now use the trace digitising tool with an offset as shown in the accompanying image.
**Această funcționalitate a fost finanțată de d.b.g. Datenbankgesellschaft mbH
Această funcționalitate a fost dezvoltată de Martin Dobias
The Node tool (now renamed to Vertex tool) has undergone a complete rework to make it more flexible. Some of the more important changes are:
Instead of requiring users to first select a feature and then edit its vertices in the second step, the tool now capable of working with multiple features at the same time. It is therefore easy to select vertices from several features and move or delete them at once. If there is a need to constrain selection of vertices to just specific feature(s), it is possible to select the features with selection tool first - the vertex tool will only work with vertices from selected feature(s) in such cases.
Instead of working just with the currently selected layer, the tool is now able to work with all layers that are in editing mode at the same time. Moving of features that logically belong together but are located in different layers has got much easier. Still, the current layer is respected if there are multiple choices when picking vertices.
Features and their vertices get highlighted as the user moves the mouse pointer over them, giving better visual feedback.
In QGIS 2.x the vertices would be moved by clicking a vertex, dragging it with the left mouse button still pressed and finally dropping them by releasing the mouse button. This behavior has been changed to „click-click” approach where user first clicks a vertex to pick it, then drag it without having any mouse buttons pressed and drop it by clicking again on the final destination. The arguments for this change were the following:
it is easier to precisely place nodes (not having to apply force to the mouse button all the time)
one does not move nodes inadvertently
it is possible to cancel the operation
it allows to pan the map by pressing space bar while the node is being moved
Parcurgeți https://github.com/qgis/QGIS-Enhancement-Proposals/issues/69 pentru mai multe informații.
**Această funcționalitate a fost finanțată de QWAT
Această funcționalitate a fost dezvoltată de Martin Dobias (Lutra Consulting)
The improved vertex tool now also displays extra markers on the mid-point of line segments of features. Clicking such marker results in addition of a new vertex. The existing way of adding vertices by double-clicking segments has been kept.
**Această funcționalitate a fost finanțată de QWAT
Această funcționalitate a fost dezvoltată de Martin Dobias (Lutra Consulting)
When editing linestring geometries with the vertex tool, moving the mouse towards the first or the last vertex will display an extra marker just next to the endpoint. Clicking the marker will add a vertex at the end of the geometry.
**Această funcționalitate a fost finanțată de QWAT
Această funcționalitate a fost dezvoltată de Martin Dobias (Lutra Consulting)
The advanced digitizing panel now works also with the vertex tool - it is possible to enter coordinates of new or existing vertices in the panel just like in other digitizing map tools.
**Această funcționalitate a fost finanțată de QWAT
Această funcționalitate a fost dezvoltată de Martin Dobias (Lutra Consulting)
Această funcționalitate a fost dezvoltată de Marco Hugentobler
A new tab is available in vector layer properties to manage auxiliary storage :
A new action Store data in the project is available in the data defined menu providing an easy way to manage auxiliary data for a property :
Auxiliary data is stored in a sqlite database and managed thanks to the OGR data provider (instead of the spatialite provider) to keep as small as possible the database file. This database file (with extension .qgd) is either saved just next to the project file or directly embedded within the new .qgz format.
See the original pull request and this article which explains more
Această funcționalitate a fost dezvoltată de Paul Blottiere / Oslandia
The metadata system in QGIS has been overhauled. In QGIS 3.0 we introduce our own internal, formalised metadata schema which is separate from the QGIS project file format. We introduce new API capabilities for reading and writing metadata for layers. We have separated the display of metatadata from the editing and have added a new metadata editing tool. Metadata are currently saved in the project file. It can also be saved as an XML file alongside file based layers or in a local sqlite database for remote layers (e.g. PostGIS).
you can read more about the design considerations adopted in this work by referring to the QGIS Enhancement Proposal (QEP) - QEP-92
Please note this is the first phase in the development of a complete and standards compliant metadata infrastructure for QGIS. We are seeking further funding to implement a more complete implementation for the metadata system - see this document for details of future planned work packages that need funding.
The specification for the QGIS metadata schema is here.
The primary funder for this work was The WorldBank/GFDRR with supporting funding provided by NINA.
**Această funcționalitate a fost finanțată de WorldBank/GFDRR
**Această funcționalitate a fost dezvoltată de Kartoza and collaborators
A single unified dialog to handle data source management and layers loading.
Această facilitate a fost finanțată de Boundless
Această funcționalitate a fost dezvoltată de Alessandro Pasotti
We have removed the OSM downloader tool that was provided in 2.x releases of QGIS. We encourage you to rather use the QuickOSM plugin which has been ported to QGIS 3.0.
In the drag and drop designer, a double click on an item will allow controlling if the label should be shown for each item individually.
Această funcționalitate a fost dezvoltată de Matthias Kuhn
This adds a new configuration option to conditionally show or hide tabs and groupboxes in drag and drop designer forms. Configuration is done via a double click in the designer tree in the fields configuration interface. An expression can be entered to control the visibility. The expression will be re-evaluated everytime values in the form change and the tab or groupbox shown/hidden accordingly.
Această funcționalitate a fost dezvoltată de Matthias Kuhn
Now the widgets can give a score on how well they could handle the type of a field. Leading to better default widgets.
Additionally, plugins can be added to choose a widget type in function of external information. One of them uses a table in PostgreSQL, allowing to specify the widget type and configuration to use for each field.
Automatically pick RelationReference widgets for foreign keys.
Această funcționalitate a fost dezvoltată de Patrick Valsecchi
Non-enforced constraints just show a warning to the user, but do not prevent committing the feature. Enforced constraints block users from committing non compliant features. So we have soft warnings now! Any constraints detected by the provider are always enforced.
Această facilitate a fost finanțată de OpenGIS.ch
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Within the attribute table, there is a new button to trigger actions which are not based on individual features but instead on the whole layer. Normally they will perform actions based on all features or the selection.
Această funcționalitate a fost dezvoltată de Matthias Kuhn
The autocompleter is nicely updated in the background so that the gui remains nice and responsive, even if there’s millions of records in the associated table.
It’s now used as a search widget for text fields, so can be seen in the browser window if you set the filter to a text field, or if you launch the form based select/filter by selecting a layer and pressing F3.
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Allows very quick navigation and identification of features which match the criteria in the form
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
Allows you to quickly hide all deselected layers. This is very handy when you have a large project and want to quickly hide all except for a couple of layers
Această funcționalitate a fost finanțată de SMEC (Surbana Jurong)
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Checking/unchecking a group doesn’t change the check state of its children. A node is visible if and only if it is checked and all its parents too.
There is no more a semi-checked state for a group
Ctrl-clic on a unchecked group will check the group and all its descendants.
Clic on a unchecked layer will check the lager and all its parents.
Ctrl-clic on a checked group will uncheck the group and all its descendants.
Ctrl-clic on a checked layer will uncheck the layer and all its parents.
Those actions are available in contextual menu items in the tree view.
Invisible layers because they or their parent(s) is unchecked are greyed out.
Această funcționalitate a fost dezvoltată de Even Rouault
It is now possible to independently control horizontal and vertical line rendering of composer table items. This added flexibility expends the styling possibilities of this item directly within QGIS.
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
Această funcționalitate a fost finanțată de SMEC (Surbana Jurong)
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
This allows the CRS for map items to differ from the canvas/project CRS. It also allows different map items to have different CRS, eg an overview map can be set to a different CRS to the main map.
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Item frame and background colors Data defined svg colors and outline width for composer picture items (Especially useful when the picture is showing a north arrow!) Data defined legend titles and column count Data defined scalebar colors and line width
Această facilitate a fost finanțată prin Programul de Granturi QGIS
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
This is a major rework to how compositions are managed in the code of QGIS.
Highlights are:
A new QgsLayoutManager class which is used for storage and serializing/deserializing of compositions. A QgsLayoutManager is attached to QgsProject. This allows core code to access the compositions attached to a project. All handling of compositions has been moved from app to core, making it easy for server (and other non-app based projects. QField/roam?) to access project compositions without resorting to fragile xml parsing.
Composer windows are created on demand and destroyed on close. This avoids the heavy requirement of creating all composer windows and widgets for every single composer item when loading projects. It was the main reason loading projects with compositions were so slow previously. Now, composer windows are created only when the window is opened and destroyed when the window is closed. Composer item configuration widgets are also only created on demand (when an item is selected) instead of precreating all widgets.
A side benefit of destroying composer windows on close is that we now no longer suffer from a Qt bug which blocked use of floating docks in composer windows. Now you can float the item/composition/etc panels! Much nicer for full screen working with compositions on multi-monitor setups.
Reworked API for working with composers through iface. Since composer windows don’t exist unless they are currently open, all the iface methods for interacting with composers have been redone to make it clear that they only apply to open windows. Additionally, a simple composer interface which provides a stable API for plugins and scripts to work with composer windows has been added. Very basic for now, but in future we can extend with more hooks to allow plugins to interact with composer windows.
Lots of code cleanups and removal
Mai multe informații la https://north-road.com/qgis-layout-and-reporting-engine-campaign/
Această facilitate a fost finanțată de Grupul Utilizatorilor Elvețieni de QGIS, alături de mulți alții!
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
http://imhere-asia.com/blog/post/qgis-raster-layer-unique-values-count
Această funcționalitate a fost dezvoltată de http://imhere-asia.com/
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
This change allows users to choose which method to use when running the simplify geometries algorithm, with choices of the existing distance based (Douglas Peucker) algorithm, area based (Visvalingam) algorithm and snap-to-grid.
Visvaligam in particular usually results in more cartographically pleasing simplification over the standard distance based methods.
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Model child algorithm inputs are now filtered to only those which generate applicable geometry types for the input to another child algorithm
Această funcționalitate a fost dezvoltată de Alexander Bruy
Add option to QgsGeometry::smooth to not smooth segments shorter than a certain threshold or sharp corners with an angle exceeding a threshold
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Many more algorithms now respect Z/M values and do not discard this information, and additionally many algorithms now correctly maintain curved geometries without forced segmentization of these geometries.
The following algorithms were added to Processing from the Raster Analysis plugin:
Orientarea
Pantă
Grad fragmentare
Umbra versanților
Relief
Now these algorithms can be used in scripts, models and for batch processing.
Această funcționalitate a fost dezvoltată de Alexander Bruy
This algorithm allows you to extract specific nodes from geometries. Eg you can extract the first or last node in the geometry.
The algorithm accepts a comma separated list of node indices to extract, eg 0 = first node, 1 = second node, etc. Negative indices can be used to extract nodes from the end of the geometry. Eg -1 = last node, -2 = second last node.
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Această funcționalitate a fost dezvoltată de Alexander Bruy
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
Allows extending linestrings by a set distance at the start and end of the line
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Filters an input layer by expression
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
Expose IDW and TIN interpolation from Interpolation plugin in toolbox
Interpolation plugin has been removed as a result
Această funcționalitate a fost dezvoltată de Alexander Bruy
This algorithm updates existing geometries (or creates new geometries) for input features by use of a QGIS expression. This allows complex geometry modifications which can utilise all the flexibility of the QGIS expression engine to manipulate and create geometries for output features.
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Port the Geometry Snapper plugin to processing
Snap geometries algorithm allows snapping to other layer types, supports point/line layers
Snap to layer algorithm accepts a mode parameter. With a new option to prefer to snap to closest point on geometry. The old behaviour was to prefer to snap to nodes, even if a node was further from the input geometry than a segment. The new option allows you to snap geometries to the closest point, regardless of whether it’s a node or segment.
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
This adds a new input type for expression inputs. Expression inputs can be linked to a parent layer so that the builder shows the correct fields and layer variables.
It’s designed to be used when an algorithm specifically requires an expression, eg Select by Expression and Extract by Expression.
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Rename algorithm SplitLinesWithLines to SplitWithLines Accept polygon as input, too Use only selected lines to split with (if processing is set to use selection only) Issue log message if trying to split multi geometries Update help
Această funcționalitate a fost dezvoltată de Bernhard Ströbl
Implements a processing algorithm to calculate the pole of inaccessibility for a surface, which is the most distant internal point from the boundary of the surface. This function uses the «polylabel» algorithm (Vladimir Agafonkin, 2016), which is an iterative approach guaranteed to find the true pole of inaccessibility within a specified tolerance. More precise tolerances require more iterations and will take longer to calculate.
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Adds support for filtering where an attribute value is null or not null
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Allows creation of an index on an attribute in a layer for faster attribute based filtering
Support depends on the underlying data provider for the layer
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Simply removes any geometries from an input layer and returns the features with attributes only
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Replaces the existing «Basic Stats for Numeric Fields» and «Basic Stats for String Fields» algorithms and adds support for date/time/datetime fields.
Having a single unified algorithm allows more flexible models where a field type may not be known in advance.
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Adds a new algorithm which tries to make angles in geometries either right angles or straight lines
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
add shortest path and service area algorithms to Processing
also allow calculating shortest path from a point to all points in a layer, or from all points in a layer to an end point. And creating service areas for all points in a layer.
Roadgraph plugin has been removed as a result.
Această funcționalitate a fost dezvoltată de Alexander Bruy
In addition to exporting processing models as bitmap images, it is now possible to export processing models as resolution-independent PDFs and SVGs. This allows for high-resolution export of models which can be embedded into papers and books being published.
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
Irretrievably deletes all features from a table… use with caution!
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Această funcționalitate a fost dezvoltată de Victor Olaya
Această funcționalitate a fost dezvoltată de Alexander Bruy
Această funcționalitate a fost dezvoltată de Alexander Bruy
Reworked centroid algorithm which handles non-polygon layers
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Extract nodes algorithm now saves node index, distance along line and angle at node
Această funcționalitate a fost finanțată de Andreas Neumann
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Allows geometries to be shifted by a x/y displacement
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
The processing modeler window has received a lot of attention for this release. Improvements include: - zoom controls in the window’s toolbar - customization of inputs and algorithms panels» location - panels can now float above the processing window
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
A new algorithm was added to processing which returns the count and area of each unique value within a given raster layer.
Această funcționalitate a fost dezvoltată de Mathieu Pellerin
We have removed the TauDEM provider from processing.
Download a file from Processing. Query a remote API to get a geojson
Această funcționalitate a fost dezvoltată de Etienne Trimaille
Supports also polygon geometries, handles null geometries, and records the original line angle along with the distance for each point.
Această funcționalitate a fost finanțată de Andreas Neumann
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Această funcționalitate a fost finanțată de DFAT/DMI
Această funcționalitate a fost dezvoltată de Etienne Trimaille (Kartoza)
A long time ago on the developper’s mailing list, we discussed of a container storing the xml file and other ressources. This is now possible, though it remains optional. The auxiliary storage feature takes advantage of that by storing the associated .qgd sqlite database. We hope that in next versions land support for embedding other resources like SVG, color ramps, datasources, images, etc…
Această funcționalitate a fost finanțată de Ministerul Francez de Ecologie, Dezvoltare Sustenabilă și Energie
Această funcționalitate a fost dezvoltată de OSLANDIA - Paul Blottiere
All user settings/plugins, etc are now loaded from the app data location for each platform and no longer .qgis3/2. Settings and plugins in each profile are now isolated from each other.
This allows for different runtime setups depending on what the user needs, e.g test, prod, demo, etc
Profile menu allows for switching between profiles or creating new ones.
Această funcționalitate a fost dezvoltată de Nathan Woodrow
Makes it easy to e.g. store your temporary layers in PostGIS
Această funcționalitate a fost dezvoltată de Martin Dobias
We have removed the standalone QGIS Browser application that shipped with QGIS 2.x. This application had poor user uptake and represented a maintenance overhead that we do not wish to continue with in the 3.0 code base.
You can now use a single dialog to add a huge variety of data formats to QGIS.
Această funcționalitate a fost dezvoltată de Alessandro Pasotti
processing uses pkg by default
save as uses pkg by default
create new layer uses pkg by default
browser drag and drop import layers
Această funcționalitate a fost dezvoltată de Alessandro Pasotti
Această funcționalitate a fost dezvoltată de Nyall Dawson
Support for Z dimension and M values was added to QGIS» gpkg, spatialite and memory layer provider. the option to add Z and M dimensions has also been added to the „create new layer” dialogs
Această funcționalitate a fost finanțată de QWAT group, http://www.imhere-asia.com/
Această funcționalitate a fost dezvoltată de Mathieu Pellerin, Alexander Bury, Paul Blottiere
Automatic detection of provider-side unique and not-null constraints implemented for postgres, spatialite, ogr provider
Client side unique and not-null constraints can be set within QGIS.
Unique constraints are enforced in attribute form
Această facilitate a fost finanțată de OpenGIS.ch
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
GeoNode is an open source geospatial content management system that makes it easy to publish geospatial data on the web. QGIS 3.0 includes new functionality that will allow you to very easily add a GeoNode instance to the browser tree and add any layers from that site to your project as WMS, WFS or XYZ. There is no need to dig around trying to figure out WMS/WFS end points, QGIS will do everything for you. When using WMS and XYZ Tiled layers, the style of the published GeoNode layer will be used.
If the GeoNode instance uses the QGIS Server backend rather than a GeoServer backed, you can copy and paste styles from the server and apply them to your local layer so that your WFS layer renders exactly as it does on the server (as shown in the animated GIF here).
There are also python bindings so that you can add GeoServer layers to QGIS from your plugins. If you are interested in running your own GeoNode with QGIS Server backend please see this site for details on how you can do that using docker and rancher.
Această funcționalitate a fost finanțată de WorldBank/GFDRR
Această funcționalitate a fost dezvoltată de Kartoza
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Allows creation of attribute indexes for spatialite layers
Această funcționalitate a fost finanțată de North Road
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
Supported by postgres, spatialite
Această funcționalitate a fost dezvoltată de Patrick Valsecchi
Această funcționalitate a fost dezvoltată de Patrick Valsecchi
This allows to declare data dependencies between layers. A data dependency occurs when a data modification in a layer, not by direct user manipulation may modify data of other layers. This is the case for instance when geometry of a layer is updated by a database trigger after modification of another layer’s geometry.
Această funcționalitate a fost dezvoltată de Hugo Mercier
Această funcționalitate a fost dezvoltată de Juergen E. Fischer
Această funcționalitate a fost dezvoltată de Even Rouault
Improve handling of defaults (inc provider default clauses, literal defaults, and QGIS expression defaults) and automatically handle unique value constraints on layers
Any fields with unique value constraints will be guaranteed to have a value which is unique to the field.
This also means that after certain editing operations (e.g. copy-paste, split features etc.) attributes will now be set to their default value, if applicable.
Această funcționalitate a fost finanțată de Cantonul Zug și de Proiectul QGEP
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
As you may know, QGIS is jumping to a new major version (yes!). Doing so was made necessary because of the need to switch to python 3, QT5, but also because we needed to break the QGIS API in several places. (http://blog.qgis.org/2016/02/10/qgis-3-0-plans/)
A year ago, a tiny troll from switzerland rang a bell about the strong need for love server code base required. Indeed, the API was locked by some old methods of QGIS server. In short, QGIS server was reparsing the qgs project file in his own way, and created dependencies to part of QGIS we needed to drop.
As outsourcing the server code base was not an option, so we had to refactor it. The involved parties decided to get engaged in a code sprint in the city of Lyon, France dedicated to sharing their vision, planning the work and finally making all the following happen:
Higher level refactoring
All services (WMS GetMap, WFS GetFeature, GetLegendGraphics, WCS, GetPrint etc..) have been rewritten. Some like WMS were entirely rewritten. Kudos to the devs!
New features
Multi-thread rendering like in the desktop
A new option to trust layer metadata and thus speed up project loading
Suport pentru WFS 1.1 https://github.com/qgis/QGIS/pull/5297
Full Python bindings for the server API
Server Services as plugins like providers
Deep, complex and unrewarding tasks
Remove all singleton calls
Cut all the dependencies to the old QGIS project file parser
Minimize dependencies to GUI library. Since fonts are necessary to render maps, totally removing them was not feasable.
Infrastructure tasks
Build a OGC compliancy platform and integrate it to a continuous integration platform. Conformity reports are now pushed to tests.qgis.org
Add unit tests … and again more unit tests
Stress QGIS server against security leaks (SQL injections and other malicious attacks)
Start profiling and bench marking performances. This work still need some love - and funding - to be achieved
A presentation was given at FOSS4G-EU in July.
Această funcționalitate a fost finanțată din donațiile către proiectul QGIS.org
Many web clients can’t display circular arcs in geometries. To allow such clients to still display a feature’s geometry (e.g. for highlighting the feature), a new per project QGIS server option was introduced (Menu „Project” -> „Project Properties” -> „QGIS Server”) to segmentize the geometry before sending it to the client in a GetFeatureInfo response.
Această funcționalitate a fost finanțată de Cantonul Zug,
Această funcționalitate a fost dezvoltată de Marco Hugentobler
În cazul straturilor de largi dimensiuni, această facilitate permite editarea offline doar a unui subset de entități
Această funcționalitate a fost finanțată de DB Fahrwegdienste GmbH
Această funcționalitate a fost dezvoltată de Matthias Kuhn
GDALTools plugin has been removed.
All functions previously available through the GDALTools plugin were moved to the QGIS Processing framework, allowing to use these tools in scripts, models and execute them in batch processes. Additionaly we updated the algorithms with new parameters, introduced in latest GDAL versions and improved overall UI/UX by exposing some advanced parameters like creation options, NODATA value settings etc.
Această funcționalitate a fost dezvoltată de Alexander Bruy
It is now more easy to install plugins manually without having to unzip them in the user profile directory by hand.
Această funcționalitate a fost dezvoltată de Alexander Bruy
Plugin-urile specializate pe furnizarea de expresii pot dispune de ajutor particularizat, realizat cu șiruri HTML.
Această funcționalitate a fost finanțată de DFAT/DMI
Această funcționalitate a fost dezvoltată de Etienne Trimaille (Kartoza)
There has been a major overhaul of the geometry classes in QGIS. The old classes have been renamed (as per the table below). New geometry classes will properly preserve Z and M attributes if present.
Referințe https://github.com/qgis/qgis3.0_api/issues/11
În final, s-a ajuns la consecvență pentru denumirile din cadrul API-ului geometriilor
QGIS 2 |
QGIS 3 |
---|---|
QgsPolygon |
QgsPolygonXY |
QgsMultiPoint |
QgsMultiPointXY |
QgsMultiPolyline |
QgsMultiPolylineXY |
QgsMultiPolygon |
QgsMultiPolygonXY |
QgsPolygonV2 |
QgsPolygon |
QgsMultiPointV2 |
QgsMultiPoint |
QgsMultiPolylineV2 |
QgsMultiPolyline |
QgsMultiPolygonV2 |
QgsMultiPolygon |
Consultați și https://github.com/qgis/QGIS/pull/5491
Această funcționalitate a fost dezvoltată de Matthias, Nyall și alții
Introduce un cadru centralizat, dedicat creării și gestionării unor activități a căror execuție are loc în fundal
S-au adaugat noi clase: - QgsTask. O interfață pentru activitățile cu execuție îndelungată în fundal - QgsTaskManager. Dedicată gestionării grupurilor de activități, fiind disponibilă și ca membru a clasei QgsApplication, pentru a urmări activitățile la nivel de aplicație
S-a adăugat o metodă python simplă, QgsTask.fromFunction, în scopul creării de activități pentru o funcție fără a se crea o subclasă QgsTask
Suport pentru activități dependente
Cancelling a task on which others depend leads to all these other tasks getting cancelled as well.
Add handling of dependent layers to task manager
If a task has dependent layers which are about to be removed, the task will automatically be cancelled
QgsTasks can have subtasks
Now, a QgsTask can have subtask QgsTasks set by calling QgsTask::addSubTask. Sub tasks can have their own set of dependent tasks.
Subtasks are not visible to users, and users only see the overall progress and status of the parent task.
This allows creation of tasks which are themselves built off many smaller component tasks. The task manager will still handle firing up and scheduling the subtasks, so eg subtasks can run in parallel (if their dependancies allow this).
Subtasks can themselves have subtasks.
This change is designed to allow the processing concept of algorithms and modeller algorithms to be translatable directly to the task manager architecture.
Această facilitate a fost finanțată prin Programul de Granturi QGIS
Această funcționalitate a fost dezvoltată de Nyall Dawson (North Road)
QgsDataItem implementations may provide hasDragEnabled(), mimeUri() and QgsCustomDropHandler implementation to deal with drop of custom items.
Această funcționalitate a fost dezvoltată de Martin Dobias