/Delphi-samples

Delphi project samples for Windows, Mac, iOS, Android, Linux, internet of things and web

Primary LanguagePascalGNU Affero General Public License v3.0AGPL-3.0

Delphi sample projects

Cette page en français.

Set of projects demonstrating the features of the Delphi development environment, its libraries and its programming language.

Some of the projects have been presented at conferences, on training courses or online coding sessions.

The programs are up to date with the Community Edition and the commercial version of Delphi or RAD Studio.

You don't know what Delphi is and where to download it ? You'll learn more on this web site.

A lot of code repositories show other Delphi project samples. Some of them are listed on this page. Be free to update it with a PULL REQUEST or by filling an issue.

Talks and conferences

Twitch

Follow my development streams of software, video games, mobile applications and websites on my Twitch channel or as replays on Serial Streameur mostly in French.

Source code installation

To download this code repository, we recommend using "git", but you can also download a ZIP file directly from its GitHub repository.

This project uses dependencies in the form of sub-modules. They will be absent from the ZIP file. You'll have to download them by hand.

Some projects needs sample databases installed as option with Delphi samples. If you don't have them, you'll find them in menu "Tools / Manage plateforms" then tab item "other options" and "samples" to install.

The sample ClientServer-Samples\004-EnvoiPhotosParSocket uses the Socket Messaging Library for the socket communication over an TCP/IP network.

The ClientServer-Samples\005-SetupAMobileAppWithQRCode example uses the ZXing.Delphi library to decode a QR code and the DelphiZXingQRCode library to create a QR code.

The sample FireDAC-Samples\003-CDataRSS uses the FireDAC RSS driver from CData. (if you use the evaluation release, compile in 64 bits, the 32 bits DLL is not available)

The sample FireDAC-Samples\004-MultiDBSample uses the FireDAC RSS driver from CData. (if you use the evaluation release, compile in 64 bits, the 32 bits DLL is not available)

The sample IoT-Samples\002-BeaconFence uses "Beacon Fence" components from GetIt.

The sample IoT-Samples\004-Arduino-Mastermind uses "AsyncPro for VCL" components from GetIt and Visuino IDE for the Arduino program.

The sample IoT-Samples\005-Joystick uses "Radiant Shape" components from GetIt, "CommunicationLab" library from Boian Mitov and Visuino IDE for the Arduino program.

The sample Web-Samples\011-UniGUI uses UniGUI.

The sample Web-Samples\012-UniGUI-Database uses UniGUI.

The sample Web-Samples\013-TMSWebCore-HelloWorld uses TMS Web Core.

The sample Web-Samples\014-TMSWebCore-DisplayJSON uses TMS Web Core.

Compatibility

As an Embarcadero MVP, I benefit from the latest versions of Delphi and C++ Builder in RAD Studio as soon as they are released. I therefore work with these versions.

Normally, my libraries and components should also run on at least the current version of Delphi Community Edition.

There's no guarantee of compatibility with earlier versions, even though I try to keep my code clean and avoid using too many of the new ways of writing in it (type inference, inline var and multiline strings).

If you detect any anomalies on earlier versions, please don't hesitate to report them so that I can test and try to correct or provide a workaround.

License to use this code repository and its contents

This source code is distributed under the AGPL 3.0 or later license.

You are generally free to use the contents of this code repository anywhere, provided that:

  • you mention it in your projects
  • distribute the modifications made to the files supplied in this project under the AGPL license (leaving the original copyright notices (author, link to this repository, license) which must be supplemented by your own)
  • to distribute the source code of your creations under the AGPL license.

If this license doesn't suit your needs, you can purchase the right to use this project under the Apache License 2.0 or a dedicated commercial license (contact the author to explain your needs).

These source codes are provided as is, without warranty of any kind.

Certain elements included in this repository may be subject to third-party usage rights (images, sounds, etc.). They are not reusable in your projects unless otherwise stated.

How to ask a new feature, report a bug or a security issue ?

If you want an answer from the project owner the best way to ask for a new feature or report a bug is to go to the GitHub repository and open a new issue.

If you found a security issue please don't report it publicly before a patch is available. Explain the case by sending a private message to the author.

You also can fork the repository and contribute by submitting pull requests if you want to help. Please read the CONTRIBUTING.md file.

Support the project and its author

If you think this project is useful and want to support it, please make a donation to its author. It will help to maintain the code and binaries.

You can use one of those services :

or if you speack french you can subscribe to Zone Abo on a monthly or yearly basis and get a lot of resources as videos and articles.