Difference between revisions of "LAMW"

From Lazarus wiki
Jump to navigationJump to search
(Add LAMW github page link)
 
(52 intermediate revisions by 10 users not shown)
Line 1: Line 1:
== Note ==
+
{{LanguageBar}}
This page comes from the previous tutorial HOW_TO_INSTALL_by_Dieselnutjob.pdf (for Windows)
 
  
Now it is a Wiki you are welcome to update it when you are sure it works and/or helps.
+
{{Platform only|Android|Android|Android}}
  
Installation for Linux will be added later, for now you can checkout https://github.com/jmpessoa/lazandroidmodulewizard and read linux/new_how_to_install_by_renabor.txt.
+
[[File:lamw_git_small_circle.png|link=https://github.com/jmpessoa/lazandroidmodulewizard|LAMW]]
  
== What is LAMW ==
+
'''LAMW''': Lazarus Android Module Wizard is a wizard to create JNI Android loadable module (.so) and Android Apk using Lazarus/Free Pascal.
  
This is a set of ''Lazarus wizards'' you will launch from menus Build and Tools.
 
  
It helps to set parameters, organize libraries and to run the tools required to make APK files, used to install applications on '''Android'''.
+
'''Features:'''
  
This installation includes several packages containing components useful to develop Android Programs with Lazarus, using JNI.
+
: Native Android GUI
 +
::: AppCompat and Material Design supported!
  
== How to install on Windows ==
+
: RAD! Form designer and drag&drop component development model!
 +
::: More than 140 components!
 +
: Github Page: https://github.com/jmpessoa/lazandroidmodulewizard
  
This is working on Windows 8 and 10 Home Edition 64 bits.
 
  
=== 1) Downloads ===
+
== Get Lazarus for Android ==
  
Create folders C:\lamw and C:\lamw\projects
+
===Laz4Android 2.0.12 (Windows)===
  
Download these files in the folder C:\lamw :
+
: All cross-android compilers already installed!
  
[http://dl.google.com/android/android-sdk_r24.4.1-windows.zip SDK 24.4.1]
+
: arm-android/aarch64-android/i386-android/x86_64-android/jvm-android
  
[http://dl.google.com/android/repository/android-ndk-r10e-windows-x86.zip NDK r10e]
 
  
[http://archive.apache.org/dist/ant/binaries/apache-ant-1.9.6-bin.zip Ant 1.9.6]
+
; How to
  
[http://download.oracle.com/otn-pub/java/jdk/8u65-b14/jdk-8u65-windows-i586.exe jdk-8u65-windows-i586.exe Jdk 8u65]
+
: Install * [http://sourceforge.net/projects/laz4android/files/?source=navbar Laz4Android 2.0.12]
  
[https://sourceforge.net/projects/laz4android/files/laz4android1.5-50093-FPC3.1.1.7z/download Laz4Android 1.5-50093-FPC3.1.1]
+
{{Note|Install here: "C:\laz4android2.0.12"  (not "Program Files" !!!)}}
  
[[File:lamw_download.png]]
+
: Install * [https://github.com/jmpessoa/lazandroidmodulewizard/archive/master.zip LAMW]
  
Checkout with a svn client (Tortoise SVN )
+
{{Note|Download LAMW and unzip it in some folder (ex. "C:\laz4android2.0.12\components")}}
  
https://github.com/jmpessoa/lazandroidmodulewizard to C:\lamw\lazandroidmodulewizard
+
:: Packages installations order/sequence:
  
[[File:lamw_svn_checkout_1.png]]
+
::: tfpandroidbridge_pack.lpk (in "..../android_bridges" folder)
 +
::: lazandroidwizardpack.lpk (in ""..../android_wizard" folder)
 +
::: amw_ide_tools.lpk (in "..../ide_tools" folder)
  
[[File:lamw_svn_checkout_2.png]]
+
; Go to [[#Infrastructure|Infrastructure]].
  
'''Important Notes :'''
+
===LAMW Manager (Linux and Windows)===
  
Versions specified here are currently working, although some of them are old and even hidden by their creator/publisher.
+
{{Note|All in One! LAMW Manage produces a complete Lazarus for Android environment by automating the step [[#Infrastructure|Infrastructure]]!}}
  
But the latest stable versions are not always compatible with the tool (NDK at least).  
+
: Install * [https://github.com/dosza/LAMWManager-linux LAMW Manager Installer for Linux]
 +
: Install * [https://github.com/dosza/LAMWManager-win LAMW Manager Installer for Windows]
  
If a more recent stable version is found working well, please update the Wiki.
+
===Install LAMW using fpcupdeluxe (Linux and Windows)===
  
You may have already the kits installed somewhere else on your computer. It might lead to problems if you try to re-use them. The safer is to make new downloads in c:\lamw. Be aware to use the corresponding versions and do not use shortcuts previously installed with other versions.
+
:: [https://wiki.freepascal.org/LAMW_install_linux_fpcupdeluxe How to install on Linux (FPCUPdeluxe + LAMW)]
 +
:: [https://wiki.freepascal.org/LAMW_install_windows_fpcupdeluxe How to install on Windows (FPCUPdeluxe + LAMW)]
  
=== 2) Installations ===
+
===Do It Yourself! (Windows)===
  
Extract android-sdk_r24.4.1-windows.zip in c:\lamw\android-sdk_r24.4.1-windows
+
: Install * [https://sourceforge.net/projects/lazarus/files/Lazarus%20Windows%2064%20bits/Lazarus%202.0.12/lazarus-2.0.12-fpc-3.2.0-win64.exe/download Lazarus 2.0.12]
  
Extract android-ndk-r10e-windows-x86.zip in c:\lamw\android-ndk-r10e-windows-x86
+
{{Note|Install here: "C:\lazarus2.0.12"  (not "Program Files" !!!)}}
  
Extract apache-ant-1.9.6-bin.zip in c:\lamw\apache-ant-1.9.6
+
: Install * [https://github.com/jmpessoa/lazandroidmodulewizard/archive/master.zip LAMW]
  
Extract laz4android1.5-50093-FPC3.1.1.7z to C:\lamw\Laz4Android
+
{{Note|Download LAMW and unzip it in some folder (ex. "C:\lazarus2.0.12\components")}}
  
Execute jdk-8u65-windows-i586.exe . It will install the JDK to C:\Program Files (x86)\Java\jdk1.8.0_65\
+
:: Packages installations order/sequence:
  
[[file:lamw_java_sdk_install.png]]
+
::: tfpandroidbridge_pack.lpk (in "..../android_bridges" folder)
 +
::: lazandroidwizardpack.lpk (in ""..../android_wizard" folder)
 +
::: amw_ide_tools.lpk (in "..../ide_tools" folder)
  
'''Notes :'''
+
: Install * [https://gitlab.com/freepascal.org/fpc/source/-/archive/main/source-main.zip FPC source code (trunk)]
  
Depending on the tool you use to extract zip or 7z, be sure to have not the first folder twice.
+
:: Download FPC source code and unzip it in some folder and point up the source path in next step
  
Something like c:\lamw\android-ndk-r10e-windows-x86\android-ndk-r10e-windows-x86 will lead to errors in the subsequent steps...
 
  
== 3) Update Java development kits ==
+
: Go to Lazarus menu "Tools" >> "[LAMW] Android Module Wizard" >> "Build FPC Cross Android"
  
run C:\lamw\android-sdk-windows\SDK Manager.exe
+
{{Note|repeat the "Build and install" process  once for each architecture}}
  
# deselect Android 6.0 (API 23)
+
::: (x) Armv7a + Soft (android 32 bits << tested!)
# select Android SDK Platform-tools
 
# select Android SDK Build-tools
 
# select Android Support Library
 
# select Google USB Driver
 
# click Install 4 packages
 
# Accept license and click Install
 
# wait for downloads to finish
 
# Exit SDK Manager
 
[[file:lamw_sdk_manager_1.png]]
 
  
 +
:::: Build
  
Run C:\lamw\android-sdk-windows\SDK Manager.exe again
+
:::: Install
  
# deselect Android 6.0 (API 23)
+
::: (x) Aarch64 (android 64 bits << tested!)
# expand Android 4.2.2 (API 17)
 
# select SDK Platfrom
 
# select ARM EABI v7a System Image
 
# click Install 2 packages
 
# Accept license and click Install
 
# wait for downloads to finish
 
# Exit SDK manager
 
[[file:lamw_sdk_manager_2.png]]
 
  
== 4) Build and prepare Laz4Android ==
+
:::: Build
  
From Windows, run cmd, then :
+
:::: Install
  
cd \lamw\Laz4Android
+
{{Note|After "build" and "install" the cross-compilers and after to do  all [[#Infrastructure|Infrastructure]] go to [[#Using LAMW|Using LAMW]] and try to create your first [New] LAMW project!}}
build.bat
 
  
[[file:lamw_cmd_laz4android_1.png]]
+
:If you get an error "Fatal: Cannot find unit system used by fcllaz of package FCL" when trying "Run"  >> "Build"  your project then go to "fpc.cfg"  (ex. "C:\lazarus2.0.12\fpc\3.2.0\bin") and:
  
[[file:lamw_cmd_laz4android_2.png]]
+
:: '''change:'''
  
When finished, exit cmd mode
+
::: #searchpath for units and other system dependent things
  
Create a shortcut on your desktop for C:\lamw\laz4android\startlazarus.exe
+
::: -FuC:\lazarus2.0.12\fpc\$FPCVERSION/units/$fpctarget
  
Execute it
+
::: -FuC:\lazarus2.0.12\fpc\$FPCVERSION/units/$fpctarget/*
 +
 +
::: -FuC:\lazarus2.0.12\fpc\$FPCVERSION/units/$fpctarget/rtl
 +
 
 +
:: '''to:'''       
 +
 
 +
::: #searchpath for units and other system dependent things
 +
 
 +
::: -FuC:\lazarus2.0.12\fpc\3.2.0/units/$fpctarget
 +
 
 +
::: -FuC:\lazarus2.0.12\fpc\3.2.0/units/$fpctarget/*
 +
 +
::: -FuC:\lazarus2.0.12\fpc\3.2.0/units/$fpctarget/rtl
 +
 
 +
         
 +
: And go to Lazarus IDE menu "Tools" >> "Options" >> "Environment" >> [FPC Source]
  
Start IDE
+
::'''change:'''
  
Package -> Open package file (.lpk)
+
::: $(LazarusDir)fpc\$(FPCVer)\source
  
select C:\lamw\lazandroidmodulewizard\trunk\tfpandroidbridge_pack.lpk
+
:: '''to:'''
 +
                       
 +
::: $(LazarusDir)fpc\3.2.0\source
 +
         
  
Compile
+
==Infrastructure==
  
Use>> Install
+
{{Note|Only for non-users of LAMW Manager!}}
  
Do you want to rebuid Lazarus now? Yes
+
===Get Java JDK===
+
: Install * [http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html Java JDK 8]
Laz4Android will restart
 
  
Package -> Open package file (.lpk)
+
===Get Android NDK===
 +
: Install * [https://github.com/android/ndk/wiki/Unsupported-Downloads r19c]
  
select C:\lamw\lazandroidmodulewizard\trunk\lazandroidwizardpack.lpk
+
===Get Ant builder===
 +
: Install * [http://ant.apache.org/bindownload.cgi Ant]
  
Compile
+
:: Simply extract the zip file to a convenient location...
  
Use>> Install
+
===Get Gradle builder===
 +
: Install * [https://gradle.org/next-steps/?version=6.6.1&format=bin Gradle 6.6.1]
  
Do you want to rebuid Lazarus now? Yes
+
{{Note|Use the option "extract here" to produce the folder "gradle-6.6.1" in a convenient location...}}
  
Laz4Android will restart
+
===Get Android SDK===
 +
: Install * [https://dl.google.com/android/repository/tools_r25.2.5-windows.zip r25.2.5-windows]
  
Package -> Open package file (.lpk)
+
: Install * [https://dl.google.com/android/repository/tools_r25.2.5-linux.zip r25.2.5-linux]
  
select C:\lamw\lazandroidmodulewizard\trunk\ide_tools\amw_ide_tools.lpk
+
: Install * [https://dl.google.com/android/repository/tools_r25.2.5-macosx.zip r25.2.5-macosx]
  
Compile
+
; How to
  
Use>> Install
+
: unpacked/install to a "sdk" folder
  
Do you want to rebuid Lazarus now? Yes
+
: open a command line terminal and go to folder "sdk/tools"
  
Laz4Android will restart
+
: run the command  >> "android update sdk"  to open a GUI "SDK Manager"
  
== 5) Path settings ==
+
:: Go to [Tools] and keep "as is"
  
In Laz4Android :
+
::: Android SDK Tools  (installed)
 +
::: (x) Android SDK Platform-Tools
 +
::: (x) Android SDK Build-Tools 29.0.3 (and others more recent)
  
Tools -> [LAMW] Android Module Wizard -> Path settings
+
:: Go to [Android R] and uncheck all!
  
Path to Java JDK: C:\Program Files (x86)\Java\jdk1.8.0_65
+
:: Go to [Android 10 API 29] uncheck all and check only
Path to Ant bin: C:\lamw\apache-ant-1.9.6\bin
 
Path to Android SDK: c:\lamw\android-sdk_r24.4.1-windows
 
Path to Android NDK: C:\lamw\android-ndk-r10e
 
NDK version: 10e
 
Path to Simonsay's templates: C:\lamw\lazandroidmodulewizard\trunk\java
 
  
[[File:lamw_path_settings.png]]
+
::: (x)SDK Platform
  
OK.
+
:: Go to [Extras] and check:
  
File -> Restart
+
::: (x)Android Support Repository
  
== 6) Create your first project ==
+
::: (x)Google USB Drive (Windows only...)
  
In Laz4Android :
+
::: (x)Google Repository
  
Project -> Close project  [if necessary]
+
::: (x)Google Play Services
  
Project Wizard -> New project
+
:: [Install 7 package!]
  
Select JNI Android Module [Lamw GUI]
 
  
OK
+
==Using LAMW==
  
[[file:lamw_create_new_project.png]]
+
===Configure Paths===
  
Path to Workspace [Projects Folder]: C:\lamw\projects
+
: Lazarus IDE menu "Tools" >> "[LAMW] Android Module Wizard" >> "Paths Settings ..."
  New Project Name: LamwGUIProject1
+
 
Default Package Name: org.lamw
+
{{Note|MacOs: path to Java JDK auto setting!}}
Include "android-support-v4.jar": no
 
NDKPlatfom: 17
 
MinSdkAPI: 17
 
TargetSdkApi: 17
 
Instruction: ARMv7a
 
ARM Fpu: Soft
 
Android Theme: DeviceDefault
 
  
[[File:lamw_configure_project.png]]
+
===Create and Run your first Android Apk===
  
Save unit1.pas
+
; How to
  
Click ''Save''
+
: From Lazarus IDE select "Project" >> "New Project"
  
Now, if you hover the mouse over any unit in uses clause, IDE will show an error message.
+
: From displayed dialog select "[LAMW] GUI Android Module" and "Ok"
  
File -> Restart
+
: Fill the form/dialog fields and "Ok"
  
After restart, if you hover the mouse over any unit in uses clause, IDE does not show error message anymore
+
{{Note|Path to Workspace" is your projects folder}}
  
Drag from Android Bridge a ''jButton'' onto form
+
{{Note|Accept "default" options! (but pay attention to the * signage)}}
  
Events OnClick, double click and add :
+
: "Save"  unit1 as/where suggested
  
procedure TAndroidModule1.jButton1Click(Sender: TObject);
+
{{Note|Search your project folder... you will find many treasures there! (look for lazarus project in ".../jni" folder)}}
begin
+
 
ShowMessage('Hello World');
+
: From Lazarus IDE select "Run" >> "Build"
end;
 
  
File -> Save All
+
:: '''Success!''' Your system is up to produce your first Android Apk!
  
Run -> Build
 
  
Target: C:\lamw\projects\LamwGUIProject1\libs\armeabi\libcontrol.so: Success
+
: Configure your phone device to [https://developer.android.com/studio/debug/dev-options debug mode] and plug it to the computer usb port
  
''Note 1 : this Build step is not required, because it will be executed by the next one. However it can help to diagnose an issue.''
 
  
''Note 2 : Before next step, check your Android device is connected to the PC with an USB cable.''
+
: From Lazarus IDE select "Run" >> "[LAMW] Build Apk and Run"
  
Run -> [Lamw] Build APK and run
+
:: '''Congratulations!''' You are now an Android Developer!
  
Building APK...: Success
+
==Other references==
  
if ADB is working with your phone, the APK will then be copied, installed and run automatically !
+
[https://github.com/jmpessoa/lazandroidmodulewizard/blob/master/docs/AppHelloWorld.md Tutorial: My First "Hello Word" App]
  
Otherwise, copy C:\lamw\projects\LamwGUIProject1\bin\LamwGUIProject1-debug.apk to some folder of the Android device, and install this file using the device file manager.
+
[[Category:Lazarus]]
 +
[[Category:Android]]

Latest revision as of 01:29, 23 May 2023

English (en) polski (pl) русский (ru)

Android robot.svg

This article applies to Android only.

See also: Multiplatform Programming Guide

LAMW

LAMW: Lazarus Android Module Wizard is a wizard to create JNI Android loadable module (.so) and Android Apk using Lazarus/Free Pascal.


Features:

Native Android GUI
AppCompat and Material Design supported!
RAD! Form designer and drag&drop component development model!
More than 140 components!
Github Page: https://github.com/jmpessoa/lazandroidmodulewizard


Get Lazarus for Android

Laz4Android 2.0.12 (Windows)

All cross-android compilers already installed!
arm-android/aarch64-android/i386-android/x86_64-android/jvm-android


How to
Install * Laz4Android 2.0.12
Light bulb  Note: Install here: "C:\laz4android2.0.12" (not "Program Files" !!!)
Install * LAMW
Light bulb  Note: Download LAMW and unzip it in some folder (ex. "C:\laz4android2.0.12\components")
Packages installations order/sequence:
tfpandroidbridge_pack.lpk (in "..../android_bridges" folder)
lazandroidwizardpack.lpk (in ""..../android_wizard" folder)
amw_ide_tools.lpk (in "..../ide_tools" folder)
Go to Infrastructure.

LAMW Manager (Linux and Windows)

Light bulb  Note: All in One! LAMW Manage produces a complete Lazarus for Android environment by automating the step Infrastructure!
Install * LAMW Manager Installer for Linux
Install * LAMW Manager Installer for Windows

Install LAMW using fpcupdeluxe (Linux and Windows)

How to install on Linux (FPCUPdeluxe + LAMW)
How to install on Windows (FPCUPdeluxe + LAMW)

Do It Yourself! (Windows)

Install * Lazarus 2.0.12
Light bulb  Note: Install here: "C:\lazarus2.0.12" (not "Program Files" !!!)
Install * LAMW
Light bulb  Note: Download LAMW and unzip it in some folder (ex. "C:\lazarus2.0.12\components")
Packages installations order/sequence:
tfpandroidbridge_pack.lpk (in "..../android_bridges" folder)
lazandroidwizardpack.lpk (in ""..../android_wizard" folder)
amw_ide_tools.lpk (in "..../ide_tools" folder)
Install * FPC source code (trunk)
Download FPC source code and unzip it in some folder and point up the source path in next step


Go to Lazarus menu "Tools" >> "[LAMW] Android Module Wizard" >> "Build FPC Cross Android"
Light bulb  Note: repeat the "Build and install" process once for each architecture
(x) Armv7a + Soft (android 32 bits << tested!)
Build
Install
(x) Aarch64 (android 64 bits << tested!)
Build
Install
Light bulb  Note: After "build" and "install" the cross-compilers and after to do all Infrastructure go to Using LAMW and try to create your first [New] LAMW project!
If you get an error "Fatal: Cannot find unit system used by fcllaz of package FCL" when trying "Run" >> "Build" your project then go to "fpc.cfg" (ex. "C:\lazarus2.0.12\fpc\3.2.0\bin") and:
change:
#searchpath for units and other system dependent things
-FuC:\lazarus2.0.12\fpc\$FPCVERSION/units/$fpctarget
-FuC:\lazarus2.0.12\fpc\$FPCVERSION/units/$fpctarget/*
-FuC:\lazarus2.0.12\fpc\$FPCVERSION/units/$fpctarget/rtl
to:
#searchpath for units and other system dependent things
-FuC:\lazarus2.0.12\fpc\3.2.0/units/$fpctarget
-FuC:\lazarus2.0.12\fpc\3.2.0/units/$fpctarget/*
-FuC:\lazarus2.0.12\fpc\3.2.0/units/$fpctarget/rtl


And go to Lazarus IDE menu "Tools" >> "Options" >> "Environment" >> [FPC Source]
change:
$(LazarusDir)fpc\$(FPCVer)\source
to:
$(LazarusDir)fpc\3.2.0\source


Infrastructure

Light bulb  Note: Only for non-users of LAMW Manager!

Get Java JDK

Install * Java JDK 8

Get Android NDK

Install * r19c

Get Ant builder

Install * Ant
Simply extract the zip file to a convenient location...

Get Gradle builder

Install * Gradle 6.6.1
Light bulb  Note: Use the option "extract here" to produce the folder "gradle-6.6.1" in a convenient location...

Get Android SDK

Install * r25.2.5-windows
Install * r25.2.5-linux
Install * r25.2.5-macosx
How to
unpacked/install to a "sdk" folder
open a command line terminal and go to folder "sdk/tools"
run the command >> "android update sdk" to open a GUI "SDK Manager"
Go to [Tools] and keep "as is"
Android SDK Tools (installed)
(x) Android SDK Platform-Tools
(x) Android SDK Build-Tools 29.0.3 (and others more recent)
Go to [Android R] and uncheck all!
Go to [Android 10 API 29] uncheck all and check only
(x)SDK Platform
Go to [Extras] and check:
(x)Android Support Repository
(x)Google USB Drive (Windows only...)
(x)Google Repository
(x)Google Play Services
[Install 7 package!]


Using LAMW

Configure Paths

Lazarus IDE menu "Tools" >> "[LAMW] Android Module Wizard" >> "Paths Settings ..."
Light bulb  Note: MacOs: path to Java JDK auto setting!

Create and Run your first Android Apk

How to
From Lazarus IDE select "Project" >> "New Project"
From displayed dialog select "[LAMW] GUI Android Module" and "Ok"
Fill the form/dialog fields and "Ok"
Light bulb  Note: Path to Workspace" is your projects folder
Light bulb  Note: Accept "default" options! (but pay attention to the * signage)
"Save" unit1 as/where suggested
Light bulb  Note: Search your project folder... you will find many treasures there! (look for lazarus project in ".../jni" folder)
From Lazarus IDE select "Run" >> "Build"
Success! Your system is up to produce your first Android Apk!


Configure your phone device to debug mode and plug it to the computer usb port


From Lazarus IDE select "Run" >> "[LAMW] Build Apk and Run"
Congratulations! You are now an Android Developer!

Other references

Tutorial: My First "Hello Word" App