wxWidgets/docs
Ian McInerney 4ac648901d Don't allow using GetPath/GetFilename() with wxFD_MULTIPLE
GetPaths/GetFilenames() must be used instead when more than one file
could be selected: document this and assert if the wrong functions are
called.

Closes https://github.com/wxWidgets/wxWidgets/pull/1883
2020-06-22 14:04:10 +02:00
..
base Remove mentions of non-existent docs/$toolkit/install.txt 2018-12-10 19:06:18 +01:00
contributing Update how-to-release instructions 2020-05-06 01:47:34 +02:00
dfb Updated links and mailing list addresses. 2015-10-30 20:06:09 -06:00
doxygen Document wxGenericAnimationCtrl XRC handler and it to XRC schema 2020-06-10 00:02:34 +02:00
gtk Update some documentation to reflect change of default GTK version for configure 2020-04-25 08:39:42 -07:00
ios Integrate MSW, OS X and iOS build instructions into doxygen 2018-10-03 19:17:14 +02:00
motif Integrate X11 and Motif install instructions into doxygen 2018-10-03 19:42:32 +02:00
msw Explain in more details how to use wxWidgets.props 2020-05-25 01:01:57 +02:00
osx Remove the section about universal binaries from macOS docs 2019-10-26 18:16:52 +02:00
publicity Prefer using https://www.wxwidgets.org/downloads/ download link 2020-04-24 23:02:16 +02:00
qt Integrate QT documentation into doxygen 2018-10-03 19:17:16 +02:00
tech Use HTTPS with Trac links. 2017-07-04 13:15:14 -06:00
univ Remove obsolete symbols from overviews and install notes 2015-12-03 21:26:31 +01:00
vms Remove all trailing spaces 2019-01-30 17:35:54 +01:00
wine Remove all trailing spaces 2019-01-30 17:35:54 +01:00
x11 Integrate X11 and Motif install instructions into doxygen 2018-10-03 19:42:32 +02:00
changes_30.txt Remove all trailing spaces 2019-01-30 17:35:54 +01:00
changes.txt Don't allow using GetPath/GetFilename() with wxFD_MULTIPLE 2020-06-22 14:04:10 +02:00
gpl.txt Update GPL and LGPL license texts to the latest versions 2020-03-26 19:50:13 -04:00
index.htm Remove mentions of non-existent docs/$toolkit/install.txt 2018-12-10 19:06:18 +01:00
lgpl.txt Update GPL and LGPL license texts to the latest versions 2020-03-26 19:50:13 -04:00
licence.txt Remove all trailing spaces 2019-01-30 17:35:54 +01:00
licendoc.txt Remove all trailing spaces 2019-01-30 17:35:54 +01:00
preamble.txt Globally use "wxWindows licence" consistently. 2010-07-13 13:29:13 +00:00
readme.txt Prefer using https://www.wxwidgets.org/downloads/ download link 2020-04-24 23:02:16 +02:00
release.md Also mention wxwidgets.props in the release notes 2019-10-27 19:11:27 +01:00
xserver.txt Remove all trailing spaces 2019-01-30 17:35:54 +01:00

wxWidgets 3.1.4 Release Notes
=============================

Welcome to the latest development release of wxWidgets, a free and open source
cross-platform C++ framework for writing advanced GUI applications using native
controls.

wxWidgets allows you to write native-looking GUI applications for all the major
desktop platforms and also helps with abstracting the differences in the non-GUI
aspects between them. It is free for the use in both open source and commercial
applications, comes with the full, easy to read and modify, source and extensive
documentation and a collection of more than a hundred examples. You can learn
more about wxWidgets at:

* https://www.wxwidgets.org/

Documentation is available online at:

* https://docs.wxwidgets.org/3.1.4/

wxWidgets sources and binaries for the selected platforms are available for
download from:

* https://www.wxwidgets.org/downloads/

or, for a more more permanent but less convenient to use link, from

* https://github.com/wxWidgets/wxWidgets/releases/tag/v3.1.4/


Changes since 3.1.2
-------------------

There have been almost 2000 commits from 97 unique contributors (52 with
multiple contributions) since 3.1.2 releases, so it is impossible to summarize
all the changes in this document without making it too long, please see the
full changelog at

https://raw.githubusercontent.com/wxWidgets/wxWidgets/v3.1.4/docs/changes.txt

for more details, but some of the most important changes are:

- Support for per-monitor DPI and dynamic DPI changes under MSW.
- More generally, many fixes for various controls appearance in high DPI.
- Long requested support for freezing rows and/or columns in wxGrid.
- New XRC handlers for wxDataViewCtrl, wxInfoBar.
- It is now possible to use gradients when creating wxGraphicsPen.
- Extended compiler (MSVS 2019) and platforms (macOS 10.14+) support.
- Significant improvements to the (still experimental) wxQt port.
- Important bug fixes for focus handling in wxOSX port.


Notice that in spite of all the changes, this release remains almost completely
compatible with 3.1.2 at the API level, so upgrading to it if you're already
using wxWidgets 3 should be straightforward.


Changes since 3.0
-----------------

Compared to the stable 3.0.x series, this version brings too many
improvements and even more bug fixes to list them all, but here is the
maximally condensed summary:

- Build system improvements: support for new compilers (up to MSVS 2019, g++ 9)
  with an even simpler way of using wxWidgets from MSVS, with wxwidgets.props
  file, and OS versions as well as an entirely new CMake build system.
- Support for native dark mode under macOS 10.14 Mojave and later.
- New features: support for mouse gesture events (GSoC 2017 project);
  fractional pen widths in wxGraphicsContext; arbitrary label windows in
  wxStaticBox; markup in wxDataViewCtrl items text; better support for high DPI
  monitors; support for ZIP 64 files; much improved accessibility support under
  MSW; Support for non-integer font sizes and arbitrary font weights; LZMA
  compression support (using liblzma)/
- New classes: wxActivityIndicator, wxAddRemoveCtrl,
  wxAppProgressIndicator, wxNativeWindow, wxPowerResourceBlocker,
  wxSecretStore.
- And methods: wxDateTime::GetWeekBasedYear(), wxListBox::GetTopItem(),
  wxProcess::Activate(), wxTextEntry::ForceUpper(), several ones in
  wxRendererNative, wxStandardPaths::GetUserDir(), wxUIActionSimulator
  ::Select() and many others.
- Significant improvements to: wxBusyInfo, wxDataViewCtrl,
  wxNotificationMessage, wxStaticBox, wxStyledTextCtrl.
- Latest versions of all bundled 3rd party libraries, including all the
  security fixed and support for WebKit 2 and GStreamer 1.7 under Unix.
- Revamped OpenGL support better suited to modern OpenGL (3.2+).
- Further C++11 support improvements.
- A lot of bug fixes, especially in wxGTK3 and wxOSX/Cocoa ports.
- New experimental wxQt port.



Platforms Supported
-------------------

This version of wxWidgets supports the following primary platforms:

* Windows XP, Vista, 7, 8 and 10 (32/64 bits).
* Most Unix variants using the GTK+ toolkit (version 2.6 or newer)
* OS X (10.7 or newer) using Cocoa (32/64 bits)

There is some support for the following platforms:

* Most Unix variants with X11
* Most Unix variants with Motif/Lesstif
* Most Unix variants with GTK+ 1.2
* Most Unix variants with Qt 5 or newer (experimental)

All C++ compilers in common use are supported; see the install.txt file for
each platform (following the links from docs/index.htm).


Files
-----

wxWidgets is distributed in source form in several archive formats. ZIP and 7z
archives are for Microsoft Windows users and contain the files with DOS/Windows
line endings while the compressed tar archives are for Unix systems (including
OS X) and contain the files with Unix line endings. Please notice that some
Windows tools still don't accept files with Unix line endings and that compiling
sources with DOS line endings under Unix will fail, so please choose the correct
file for your system.

In addition to the sources, documentation in HTML, CHM and HTB (wxWidgets help
viewer) formats is provided as well as an installer for Microsoft Windows.
Notice that you will still need to compile wxWidgets even when using the
installer.

We also supply binaries of wxMSW libraries built with several versions of
Microsoft Visual C++ and GNU g++ compiler for this release.


Installation
------------

Unless you have downloaded the binaries for your compiler, you will need to
build wxWidgets before you can test out the samples or write your own
applications. For installation information, please see the install.md files in
the docs subdirectory appropriate for the platform you use or the "Platform
Details" page of the manual, which contains links to the rendered versions of
these files.


Licence
-------

For licensing information, please see the files:

* docs/preamble.txt
* docs/licence.txt
* docs/licendoc.txt
* docs/gpl.txt
* docs/lgpl.txt
* docs/xserver.txt

Although this may seem complex, it is there to allow authors of proprietary,
commercial applications to use wxWidgets in addition to those writing GPL'ed
applications. In summary, the licence is LGPL plus a clause allowing
unrestricted distribution of application binaries. To answer a FAQ, you don't
have to distribute any source if you wish to write commercial applications using
wxWidgets.

However, if you distribute wxGTK, wxQt or wxMotif (with Lesstif) version of your
application, don't forget that it is linked against GTK+, Qt or Lesstif, which
are covered by LGPL *without* exception notice and so is bound by its
requirements.

If you use TIFF image handler, please see src/tiff/COPYRIGHT for libtiff licence
details.

If you use JPEG image handler, documentation for your program should contain
following sentence: "This software is based in part on the work of the
Independent JPEG Group". See src/jpeg/README for details.

If you use wxRegEx class on a system without native regular expressions support
(i.e. MS Windows), see src/regex/COPYRIGHT file for Henry Spencer's regular
expression library copyright.

If you use wxXML classes or XRC, see src/expat/COPYING for licence details.


Reporting Bugs
--------------

The wxWidgets bug tracker can be found here:

* https://trac.wxwidgets.org/newticket

Please use the search function of our Trac installation to find any possibly
relevant bugs before reporting new ones. Also please notice that often trying to
correct the bug yourself is the quickest way to fix it. Even if you fail to do
it, you may discover valuable information allowing us to fix it while doing it.
We also give much higher priority to bug reports with patches fixing the
problems so this ensures that your report will be addressed sooner.


Further Information
-------------------

If you are looking for community support, you can get it from

* Mailing Lists: https://www.wxwidgets.org/support/mailing-lists/
* Discussion Forums: https://forums.wxwidgets.org/
* #wxwidgets IRC Channel: https://www.wxwidgets.org/support/irc/
* Stack Overflow (tag your questions with "wxwidgets"):
  https://stackoverflow.com/questions/tagged/wxwidgets

Commercial support is also available, please see
https://www.wxwidgets.org/support/commercial/

Finally, keep in mind that wxWidgets is an open source project collaboratively
developed by its users and your contributions to it are always welcome!


Have fun!

The wxWidgets Team, October 2019