Tag Archives: C++ Builder

In-App Advertising to Monetize Your FireMonkey iOS and Android Apps

Description : How to use In-app advertising and In-app payment service in your Delphi FireMonkey mobile apps.
Objective: How to monetize iOS and Android applications using the TBannerAd component.
Presenter: Marco Cantù, Embarcadero Technologies.
Software Versions Supported: Delphi XE6, C++ Builder XE6,  RAD Studio XE6.
Event: Developer Skill Sprints
Level: All

In-App Advertising, commonly referred to as Mobile Ads, has become very popular among mobile app developers.  In-App Advertising works by allowing ads to run on space sold within your mobile app. The revenue generated from these ads are based on number of user impressions and/or clicks.

In-App Advertising is potentially a more scalable method of monetization.  Although running ads in your app can somewhat impact the user experience, it can be an excellent choice for apps with lots of content and user engagement such as games, news, chat and entertainment category apps.

One of the new features in RAD Studio XE6, is built-in support (via components) for In-App Payment Services and In-App Advertising.  The In-app payment services via the TInAppPurchase component, enable you to sell digital content directly within your iOS and Android applications.  The In-App Advertising uses the TBannerAd component to enable you to show ads on your iOS and Android applications to obtain income.

In the following video, Marco Cantù from Embarcadero Technologies does a really nice job explaining how to add Ads to Monetize your Mobile App.  Also, read his articles “Using AdMob in an Android Delphi app” and “Advertising with Delphi XE6 on iOS” for step by step examples on how to use In-App Advertising.

For more information on the above topic, see Adding In-App Payments to Your Mobile Apps and  Adding Advertising to Your Mobile Apps.

Creating Custom Delphi FireMonkey Components

Description : How to create custom components for the FireMonkey application platform.
Objective:  To enhance your mobile and desktop applications by creating custom reusable FireMonkey controls.
Presenter: Ray Konopka from Raize Software
Software Versions Supported: Delphi XE5 / XE6, RAD Studio XE5 / XE6.
Event: CodeRage 8
Level: Intermediate

Rapid application development (RAD) software solutions such as Delphi and C++ Builder uses a component-based framework that significantly reduces software development time.  RAD Studio FireMonkey components-based framework not only allows for faster delivery, more reliable systems (due to previously tested components), reusability and increase in productivity, but allows developers to target multi-device platforms (Android, iOS, Mac, Windows) from one codebase.

While RAD Studio (Delphi/C++ Builder) includes a wide range of FireMonkey components, there are often times when the base controls that comes with FireMonkey are insufficient. In the following video, Ray Konopka of Raize Software demonstrates how to enhance your mobile and desktop applications by creating custom reusable FireMonkey Components.

Read more on creating FireMonkey components on Embarcadero’s website.  Also, download Mitov Software free open source library OpenWire .  OpenWire library allows writing advanced VCL and FireMonkey components for rapid codeless application development.

Full Access to Android and iOS API using Delphi FireMonkey

Description :  You will learn how to get full access to Android and iOS API in your application using Delphi FireMonkey.
Objective: Get full access to Android and iOS API in FireMonkey.
Presenter: Brian Long from Brian Long Consultancy & Training Services Ltd
Event: CodeRage 8 and Brian Long’s Blog.
Software Versions Supported: Delphi XE5 / XE6, Appmethod
Level: Intermediate
Source code: Source code from Accessing the iOS API session and Accessing the Android API session.  Also download fmxexpress.com full set of Android SDK Object Pascal interface files on Github.

There are thousands of components and libraries (both free, commercial and open source) available for Firemonkey.  However, there will be times you will need functionality for your application that are no readily available libraries and components for. For example, you may need additional functionality for the media player component that comes out of the box with Rad Studio XE5 and XE6.  Functionality such as streaming from a remote server (on-demand) or even streaming a live event. You may also want to access methods in the AudioRecord class in Android for audio capture, but unfortunately there are no out of the box solutions currently in Rad Studio.

Embarcadero has done and is continuing to do a great job with FireMonkey to make sure it has all the essential library necessary from iOS and Android APIs.  And given time, I am sure developers will get full access to these APIs out of the box.  In the meantime, there is another way to get access to these additional APIs in your application.

Brian Long from Brian Long Consultancy & Training Services Ltd did two very interesting presentations at Coderage 8 where he did an excellent job (for such a complex topic) explaining how to access the Android and iOS API directly.  These videos are based on Delphi XE5, but since then, Brian has written two extensive articles, explaining some of the topics he covered in these videos, and the necessary updates for Delphi XE6.  After watching the videos, read Brian Long’s “Creating a splash screen for Delphi XE6 Android apps” and “Launching activities and handling results in Delphi XE6 Android apps” articles.

To bring out full access to iOS and Android APIs, an Object Pascal interface file must be created.  This interface file is the bridge to connect the Object Pascal world to the JAVA and Objective C world.  There are currently three different automated solutions available for Android to help with this process. I am not aware of any for iOS as yet. The three automated tools are  Android2Delphi (paid version – bitcoins only), Java2pas (free & paid version) and JavaImport for Android (paid version only).  Fmxexpress.com has also gone ahead and used Java2pas against the entire set of android.jar files for Android 7, Android 8, Android 10, Android 12, Android 14, Android 15, Android 16, Android 17, and Android 19.  You can read his blog post on Full Android SDK Interface Files In Object Pascal For Firemonkey.

Accessing the iOS API by Brian Long from Long Consultancy & Training Services Ltd

Accessing the Android API by Brian Long from Long Consultancy & Training Services Ltd

Choosing the Right Menu Navigation for your Mobile App

Description :  You will learn Delphi FireMonkey UI design tips and tricks when designing and creating responsive navigation menu.
Objective: How to create Navigation Side Drawer for mobile applications using FireMonkey.
Source: Malcolm Groves, José León and Sarina Dupont’s blog.
Software Versions Supported: Delphi XE4, XE5, XE6,  C++ Builder XE5, XE6, RAD Studio XE5, XE6, Appmethod.
Source Code: Source code can be downloaded from in Malcolm Groves’ Github repository.
Level: All

A common challenge when designing a responsive mobile application is the navigation menu.  There are several navigation menu options such as the Toolbar Only Navigation, the Tabbed Bar Navigation, the Side Drawer Menu, and the App Home Screen Navigation.

Two of the more commonly used navigation menus are the Tabbed Bar navigation (more commonly used in iOS apps) and the Side Drawer navigation which has become fashionable on Android.  The Tabbed bar navigation is a row of tabs along the top or buttons along the bottom of the screen.  This navigation design provides intuitive user experience allowing users to know what are their available options from one screen.  However, the downside to the tabbed bar navigation is that the tabs or buttons takes up valuable real estate on small mobile displays.

The side drawer menu on the other hand, has the  advantage of more screen real estate, but may take away user engagement, if the engaging menu options available to users has been tucked away in the side drawer.

There is an earlier article written by Malcolm Groves on how to design a Facebook-style layout for your mobile app using Delphi XE4 and Delphi XE5. Sarina Dupont has expanded on his blog post with another great article on Creating a Navigation Drawer for your Mobile Application using XE6 and Appmethod.

José León also has a video on how to create a sliding popup menu in Delphi XE5, that will show up when the user clicks a button on the toolbar. The process is very much similar to the drawer and shows you some UI design tricks to get a nice visual result.

Choosing the right Menu Navigation depends largely on users experience.  If most of the user experience takes place in a single view, and the only things such as user setting and options are needed to be accessed in seperate screens, then you should focus on having your main UI nice and clean by tucking away these settings/options in the side drawer menu. However, if your mobile app has multiple views that users will be equally engaged in, then side navigation may not be the best option.

Backend as a Service (BaaS) applications using FireMonkey

Description: How to build connected multi-device apps using Backend as a Service (BaaS).
Objective: Learn how to use BaaS in your application to  gain easy access to common services in the cloud without having to build or maintain the backend services yourself.
Presenter: David Intersimone, Embarcadero.
Event:  RAD in Action
Software Versions Supported: Delphi XE6, C++ Builder XE6, RAD Studio XE6
Level: All

One of the cool new features in RAD Studio XE6 is Backend as a Service (BaaS).  BaaS, also known as “mobile backend as a service” (MBaaS), provides mobile app developers with a way to link their applications to backend cloud storage and APIs exposed by back end applications.  It does this, while also providing features such as push notifications, user management, and integration with social networking services.  RAD Studio XE6 BaaS integrates with leading BaaS providers which includes support for Kinvey and Parse out of the box.

With BaaS, you get easy access to common services in the cloud such as

  • Build multi-device service based applications using the FireMonkey and VCL frameworks
  • Use push notifications to engage your users on any device or platform
  • Access data and object storage in the cloud
  • Provide application and storage security with user authentication
  • Work with popular BaaS providers including Kinvey and Parse using a component based API

In this RAD in Action webinar video, David I explains how to  gain easy access to common services in the cloud without having to build or maintain the back-end services yourself.

Also, check out Sarina DuPont’s Blog for several articles on BaaS.

Developing A Simple Mobile Game With Delphi FireMonkey

Description :  Developing a simple mobile game with Delphi FireMonkey.
Objective: Learn how to design and develop a Bejeweled clone game for iOS and Android mobile devices using Delphi XE5 and FireMonkey.
Presenter:Joaquin Monedero – Embarcadero.
Event:  CodeRage 8.
Software Versions Supported: Delphi XE5 / XE6
Level: All
Source code: The free source code for Bejeweled clone can be downloaded on Github.

It is being predicted by analysts that with the increasing popularity of smartphones and tablets on the market, mobile devices will be the primary hardware for gaming by 2016.  The 2013 data released by the State of the Industry Survey, 55% of the participants in last year’s Game Developers Conference are interested in porting their console and PC games for smartphones and tablets and 58% of these developers are planning on launching their next creations on mobile platforms – specifically Android and iOS.

With the gaming market growing so rapidly, Rad Studio XE6 gives developers a huge advantage with its multi platform capabilities, helping developers get to market faster than the competition.  Watch Joaquin Monedero from Embarcadero do a splendid job explaining how to design and develop games for iOS and Android mobile devices using Delphi XE5 and FireMonkey.