PixelPhoto Android Application
With PixelPhotoApp users can Post & Interact with users feeds and like and comment and more , now using the application is easier, and more fun ! PixelPhotoApp is easy, secured, and it will be regularly updated. 
Created: 1/1/2019
Latest update: 9/2/2020
By: DoughouzLight

Installation Guide


The installation is pretty easy, please follow the steps below:

  • PixelPhoto PHP Script, you can get it from Here
  • Unzip the PixelPhotoApp  archive, extract it to new folder, and then open the folder.
  • In the main folder you will find the solution (Name: PixelPhoto Type: Microsoft Visual Studio Solution) double click on it and wait till everything is loaded.
  • In the Visual Studio menu bar go to Build > Clean Solution, click it and wait till it finish.
  • Again In the Visual Studio menu bar go to Build > Build Solution, click it and wait till it finish building your project.

1) Download Visual Studio for Windows as shown below: 

2) Select This 3 check boxes as the image bellow and then press install
for (Visual studio on Windows)


3)  Install all Android SDKs in your system.
From your Visual studio go to tools menu >> Android >> SDK Manager
Select the SDK 10.0 and 9 and version 5.0 as images bellow 
And Also Download NDK’s in Tools section


After you installed the SDKs in your system, you are ready to start and build your app,
Follow step 4. 

4)  Build Your Solution > Clean Solution, click on it and wait till it finish.

Customization Guide 

Follow the steps bellow to customize your application as you want

Connect to your Domain


PixelPhoto Provides Triple DES algorithm encryption system + AES 256-Bit Encryption in your mobile application to safe your own information and your own server side keys from hackers and crackers, once you are a real buyer you will not fear any cracking or unpacking APK  actions by eligible black hat people, which may lead to leaking your sensitive server side data to the public.


Go to http://doughouzlight-license.com to get the CERT encryption key  once you have the key you will be able to add the key to your Settings.cs class as the image bellow

Server key >> is Here  ex www.testwebsite.com/admin-panel/site-settings
Purchase code >> is Here

The encryption  key includes all your domain information, you dont need to add your website or server-key or anything else on the settings class, bu sure you get the key on each new update we release to avoid any issues.

If you face any error please contact us on  https://wowonderapplications.ticksy.com

Now go to your Visual studio 2019 solution and press Save, then you are ready to proceed with your own app 

0-Change Logos & Icons and images 


In your main solution you will find 4 main folders by the following names
  • drawable >> for all android screen sizes by default
  • drawable-hdpi >>for small devices screen
  • drawable-xhdpi >> for normal devices screen 
  • drawable-xxhdpi >> for High HD screens such as Samsung s8 and s7

Replace the icons and the images which you want and add them as the same name dont change the names of your pictures

EX >> You want to replace the icon of your app add an image by name icon.png on your drawable folder and your icon will be changed.

1-Change Colors and Theme 

To customize and change the main color of the application follow the steps bellow.

1-Go to Values folder > open Colors.xml file and you will see all the xml file which is responsible for the main color and the theme of the main application 

Also the file includes secondary colors for links and buttons and etc ..

1-Go to AppSettings.cs class and change the colors bellow to your own colors


        //Main Colors >>
        //*********************************************************
        public static string MainColor = "#af0732";
        public static string StartColor = "#af0732";
        public static string EndColor = "#ff00b5";
 

2-Change Application Name.

-From your main solution right click on the PixelPhoto>> Properties >> Android Manifest tab >> Change the names as you like and the versions also depending on your google play last version if you have.
-From AppSettings class change the name as bellow 


IMPORTANT : Also you need to change your Package name from the AndroidManifest file as bellow >> 

3-Change Lang & Words and Translate

PixelPhoto Team made it for you easy to translate your own words in your app and change the labels as you want, so lets start.

  • By default the folder Values >> String.xml contains all the English words in the app which is the default language in your mobile application

  • The text strings in res/values/strings.xml should use the default language, which is the language that you expect most of your app's users to speak.

The green colored border on the image contains another translations , each folder has a String.xml file which contains same words but translated to Turkish or Russian or Arabic and etc.. 

  • You can find your language shortcut from here 

  • From your AppSettings.cs class you can set your own default language which the app will open first time 

  • Also you can force the RTL system by setting the variable FlowDirection_RightToLeft to True

4-Integrate Social Logins

From Your Facebook audience network Dashboard , choose to add new Android Application (for android )
In order to get your first ad placements , be sure to set the app as not live . so we can continue to get the placements ids 

From the list of placement types below , choose the one you want to create and use in your app.


After choosing the placement type , you will get the placement ID as shown below 

Copy the Placement id An go to your AppSettings.cs

The Other 4 line is where you have to paste the ID that you get from you Facebook Audience Network Dashboard .

The new version supports google+ Login and Facebook Login with few simple steps follow the video bellow in order to give your app the ability to use social login  
1-Navigate from your browser to Google Console
On the left slider press on credentials and press create credentials as the image bellow:
 2-Select the API which you want to use in your app as for the timeline app we are using 4 Google APIs as bellow:
 
 
 3-Be sure you select the restriction of your application to None
 
 4- Copy your Google APi key to your Solution Code > AndroidManifest as bellow:
 
 5-Go back to your google console and press OAuth client 
 6-Your package name should be as your package name on the solution then you can copy the Client ID and the Secret key  as bellow:
 7-Add the copied information to your own AppSettings.cs solution code
 
  

9-Integrate AdMob (Google ADS)


After creating google AdMob account and you are already to start your own AdMob ads system on your mobile app

You will need to follow few steps before to see your ADS appearing in your mobile application

1-Find your app IDs & ad unit IDs
An app ID is a unique ID number assigned to your apps when they're added to AdMob. The app ID is used to identify your apps.
An ad unit ID is a unique ID number assigned to each of your ad units when they're created in AdMob. The ad unit ID is added to your app's code and used to identify ad requests from the ad unit.
Find an app ID
  1. Sign in to your AdMob account at https://apps.admob.com.
  1. Click Apps in the sidebar.
  1. Click View all apps.
  1. Click the icon in the App ID column to copy the ID of an app.

Find an ad unit ID
  1. Sign in to your AdMob account at https://apps.admob.com.
  1. Click Apps in the sidebar.
  1. Click the name of the app associated with the ad unit. Note: If you don't see it in the list of recent apps, click View all apps. Then, click the name of the app.
  1. Click Ad units in the sidebar.
  1. Click the  icon in the Ad unit ID column to copy the ID of an ad unit.
Copy the APP_ID and put it on your analytic.xml file in your solution code as bellow screenshot 
2-Copy ADS IDS to your solution code 
1-Native Banners ads should be added to the analytic.xml file as ADS Image 2
2-(Interstitial , Rewarded , Native ) on AppSettings.cs class as image bellow

2-Create Firebase account
After creating firebase account from the link bellow https://console.firebase.google.com/
You will need to create a new project as well
after creating the project go to settings and as image bellow 


Go to integration tab and select the item bellow as the screenshot 

Then go and set connection as image bellow :
Add your Package android app name and press the link icon as image bellow
Download file JSON as bellow and add it to your project code:


Right click on WoWonder solution code then press on add new item, and add it to the project as the screenshot bellow 

Sign your application with a sign key you have already so the ADMob system will start to work , Our own demo keys are located here >> PixelPhoto\KeyApk



Now you are done happy earning ! 

5-Control Application Settings

From your AppSettings.cs class on your PixelPhoto project you will be able to control most of your Android App settings 


1-Enable/Disable Social Logins 
Set the variables bellow to True or false to show or hide social login ability on the application
be sure if you set to true to read this section.

//Social Logins >>
//If you want login with facebook or google you should change id key in the String.xml   file or AndroidManifest.xml
//Facebook >> ../values/Strings.xml .. line 15 - 16 
//Google >> ../Properties/AndroidManifest.xml .. line 49
//*********************************************************
 public static bool ShowFacebookLogin = true;
 public static bool ShowGoogleLogin = true;
 

2-Switch between Full/Normal screen display
Set the variables bellow to True or False

public static bool EnableFullScreenApp = false;

3-Show /Hide AdMob on your 
Set the variables bellow to True or False To hide the Banners or Reward Video ADS or Interstitial ADS 

For ore info about Google AdMob

  
  //ADMOB >> Please add the code ad Here and Strings.xml 
  //*********************************************************
  public static bool Show_ADMOB_Banner = true;
  public static bool Show_ADMOB_Interstitial = true;
  public static bool Show_ADMOB_RewardVideo = true;

  public static string Ad_Unit_ID = "ca-app-pub-5135691635931982/xxxx";
  public static string Ad_Interstitial_Key = "ca-app-pub-51356635932/xxx";
  public static string Ad_RewardVideo_Key = "ca-app-pub-51356163593/xxx";

  //Three times after entering the activty the ad is displayed
  public static int Show_ADMOB_Interstitial_Count = 3;
  public static int Show_ADMOB_RewardedVideo_Count = 3;
        

Also go to values>> Strings.xml and change the string bellow to your own Key 


  <!--AD MOB-->
  <string name="banner_ad_unit_id">"ca-app-pub-5135691635931982/xxx"</string>
  

4-Control Chat System Settings
  •  RunSoundControl Set the variable bellow to True or False to display sound during send and receive of messages 
  • RefreshChatActivitiesSeconds set speed of synchronized messages between your app and your server do not set less then 6000 for shared host 
  • MessageRequestSpeed set speed of API Get message between 2 users in main chat activity do not set less then 3000 for shared host 

 
  public static bool RunSoundControl = true;
  public static int RefreshChatActivitiesSeconds = 6000; // 6 Seconds
  public static int MessageRequestSpeed = 3000; // 3 Seconds
  

5-Disable/Enable Notification System

  • If You want to Disable Notification and Onesignal on your app set the variable bellow to False

  • RefreshDataSeconds: sets the speed of API Get Notification do not set less then 7000 for shared host 

  //Notification Settings >>
  //*********************************************************
  public static bool ShowNotification = true;
  public static int RefreshDataSeconds = 8000; // 8 Seconds

6-Control Your Add Post Types
You can force your users to post limited posts types this will take effect on add Post button (the + button on bottom of your main tabbed activity)

//Add Post
 public static bool ShowGalleryImage = true;
 public static bool ShowGalleryVideo = true;
 public static bool ShowMention = true;
 public static bool ShowCamera = true;
 public static bool ShowGif = true;
 public static bool ShowEmbedVideo = true

6-Control Users General and Privacy activity 
You can force your users to limited settings control on the settings activity 

 //Settings Page >> General Account
  public static bool ShowSettingsGeneralAccount = true;
  public static bool ShowSettingsAccountPrivacy = true;
  public static bool ShowSettingsPassword = true;
  public static bool ShowSettingsBlockedUsers = true;
  public static bool ShowSettingsNotifications = false
  public static bool ShowSettingsDeleteAccount = true;

6-Set Your Application for REPORT MODE  (API TESTING)
Set the variables bellow to True or False To start checking your API respond from your server 
if the API fails you will get a message box in your application with the error of the API 
dont forget to set the variable to false before releasing your app in google play market 

//Error Report Mode
//*********************************************************
public static bool SetApisReportMode = true;

Errors Guide

The file "obj\Debug\android\bin\packaged_resources" does not exist.


1) From Visual Studio go to "Tools->Android->Android SDK Manager".
Once that opens, look in the "Extra's" folder for "Android Support Library". Make sure you have that checked, and if you do, make sure you have the latest. Update if necessary. Also be sure you have installed all the SDKs from Android version 4.3 tell version 7.2 once you have selected all the APIs press on Install button >> Then accept terms .


3)After you are sure that you installed everything what you need and the problem still exits Copy your PixelPhoto folder to a small path like D://PixelPhoto or   C://PixelPhoto then open the solution and build the application , the path must be small not long 

"java.exe" exited with code 1. 

Right-click on Project >> Click on Android properties >> Click on Android Option >> Select Advanced Button >> Set Java Max Heap Size to 2G (or less if needed 1G) 

"java.exe" exited with code 2.


Uncheck  the checkbox from your project properties page and rebuild your application 

Application Crash/Error On Login First Page


1-Right-click on Project >> Click on Android properties >> Click on Android Option
2-On the Linking section, Set the Linking to “Sdk Assemblies only” as the image bellow 



Solution (1) Bypass the SSL Error
Go To PixelPhoto >> Settings >> AppSettings.cs
Set this 2 variables to TRUE , By default they will be false

    
  public static bool TurnTrustFailureOn_WebException = true;
  public static bool TurnSecurityProtocolType3072On = true;
  

Solution (2) Change Connection Type
Right-click on Project >> Click on Android properties >> Click on Android Option >> Select Advanced Button >> 

Set the connection type  as bellow .

You should build the app and run it on each connection type and check if it works 
HTTPClient Implementation
SSL/TLS Implementation
Server
Android
Native TLS 1.2+
This should be the Default
Default 
Default (Native TLS 1.2+)
This should be the Secondery
Managed
Managed TLS 1.0+
This is the last option you have
 
Solution (4) Host Server
Go To Your Host Control Panel
1-Click the CloudFlare icon, located in the Domains section of your control panel.
2-Click the Disable button to disable CloudFlare. EX : For Blue Host / EX : For Hostgator
3-Disable your Mod-security on your Host server totally and dont use it.

NOTE : If the problem still exits thats means your main host is using cloud system whitch prevents the application to connect to your website over SSL

1-Be sure you are not using cloud host server or your mode-security is enabled you may need to contact your host provider to disable it totally for you.

2-Change you host to a normal Host VPS or Detected server >> We recommend you to use the UltaHost.com Server which is 100% compatible with our application >> UltaHost


Push Notification System

PixelPhoto Products are using OneSignal for push notification service.

What is OneSignal?

OneSignal is a high volume and reliable push notification service for websites and mobile applications. They support all major native and mobile platforms by providing dedicated SDKs for each platform, a Restful server API, and an online dashboard for marketers to design and send push notifications.

1. Create a Firebase project

1.1 Visit the Firebase Console and sign in with your Google account.

1.2 Press "CREATE NEW PROJECT" or select an existing one below.


2. Getting your Firebase Cloud Messaging token and Sender ID:

1 Click the Gear icon in the top left and select "Project settings".
2 Select the "CLOUD MESSAGING" tab..

3 Save the two values listed:
  • You'll need your Server key, also known as the Google Server API key.
  • You'll need your Sender ID, also known as the Google Project Number, later as well

3. Configure your OneSignal app's settings

1- Go to App Settings and press the Configure button to the right of Apple IOS.

For Android >> Go to App Settings and press the Configure button to the right of Google Android
2-Paste your Google Server API Key and Google Project Number in here and press Save.

3-Copy your keys from App Settings >> Keys& ids TAB.

4-Pasta all the keys on the (Push Notifications System) Tab on Your Admin Panel ,and select Enable for Push notifications as image bellow and press save .
  1. Then Add the keys on PixelPhoto>>  OneSignal>> OneSignalNotifciation.cs

4-Change Your Push Notification Icon


1-From the Solution Explorer go to PixelPhoto>> Resources >> Drawble.

2-Add your image as the same name, it must be >> "ic_stat_onesignal_default.png

5-Change your package name to start getting notifications.


IMPORTANT : Also you need to change your Package name from the AndroidManifest file as bellow >> 
This will activate your One-signal account on your device and you are done.

Set Up Device for Development


This article will discuss how to setup an Android device and connect it to a computer so that the device may be used to run and debug Xamarin.Android applications.
By now, you've probably seen your great new application running on the Android emulator, and want to see it running on your shiny Android device. Here are the steps involved with connecting a device to a computer for debugging:

  1. Enable Debugging on the Device - By default, it will not be possible to debug applications on a Android device.
  1. Install USB Drivers - This step is not necessary for OS X computers. Windows computers may require the installation of USB drivers.
  1. Connect the Device to the Computer - The final step involves connecting the device to the computer by either USB or WiFi.

Enable Debugging on the Device
It is possible to use any Android device to test an Android application. However the device must be properly configured before debugging can occur. The steps involved are slightly different, depending on the version of Android running on the device.
Android 4.0 to Android 4.1

For Android 4.0.x to Android 4.1.x, debugging is enabled by following these steps:
  1. Go to the Settings screen.
  1. Select Developer options .
  1. Check off the USB debugging option.

This screenshot shows the Developer options screen on a device running Android 4.0.3:

Android 4.2 and higher tell 7.2
Starting in Android 4.2 and higher, the Developer options is hidden by default. To make it available, go to Settings > About phone, and tap the Build number item seven times to reveal the Developer Options tab:


Once the Developer Options tab is available under Settings > System, open it to reveal developer settings:


Install USB Drivers
This step is not necessary for OS X. Just connect the device to the the Mac with a USB cable.
It may be necessary to install some extra drivers before a Windows computer will recognize an Android device connected by USB.
Note: These are the steps to set up a Google Nexus device and are provided as a reference. Steps for your specific device may vary, but will follow a similar pattern. Search the internet for your device if you have trouble.

Download the USB Drivers
Google Nexus devices (with the exception of the Galaxy Nexus) require the Google USB Driver. The driver for the Galaxy Nexus is distributed by Samsung

All other Android devices should use the USB driver from their respective manufacturer.
Install the Google USB Driver package by starting the Android SDK Manager, and expanding the Extras folder, as can be seen in the follow screenshot:

Check the Google USB Driver box, and click the Install button. 

Connect the Device to the Computer
The final step is to connect the device to the computer. There are two ways to do so:
  • USB cable - This is the easiest and most common way. Just plug the USB cable into the device and then into the computer.
  • WiFi - It is possible to connect an Android device to a computer without using a USB cable, over WiFi. This technique requires a bit more effort but could be useful when there is no USB cable or the device is to far away for a USB cable. Connecting via WiFi will be covered Here.

Now Your device will appear in the Debug section click start and the application will be deployed to your own device.

Now you can start you own test

Publishing Application


Before starting the archive process be sure to change the application package name from the AndroidManifest.xml file as bellow to your own package name  as ex: com.websitename.Timeline

The following screenshot is how your configuration should be before the archive process 
1-Red color are very important
2-Orange color reduces the APK size (Leave it as default if you are not a developer)
3-Green Is optional when selecting AOT and Enable Startup Tracing the splash screen will be loading faster 50% but the app size will increase as well 25% so its your choice and its up to you.

 
To reduce the app size and make the APK less  please read the Article Here

1 - Archive for Publishing
To begin the publishing process, right-click the project in Solution Explorer and select the Archive... context menu item:
Archive... launches the Archive Manager and begins the process of archiving the App bundle as shown in this screenshot:


2 - Distribution:
When an archived version of the application is ready to publish, select the archive in the Archive Manager and click the Distribute... button:

The Distribution Channel dialog presented two choices for distribution. Select Ad-Hoc:

Create a New Certificate
After Ad-Hoc is selected, Visual Studio opens the Signing Identity page of the dialog as shown in the next screenshot. To publish the .APK, it must first be signed with a signing key (also referred to as a certificate). An existing certificate can be used by clicking the Import button and then proceeding to Sign the APK. Otherwise, click the click the + button to create a new certificate:

The Create Android Key Store dialog is displayed; use this dialog to create a new signing certificate that can use for signing Android applications. Enter the required information (outlined in red) as shown in this dialog:

The resulting keystore resides in the following location: (Save Them)
(C:\Users\USERNAME\AppData\Local\Xamarin\Mono for Android\alias\alias.keystore)
For example, the above steps might create a new signing key in the following location:
(C:\Users\USERNAME\AppData\Local\Xamarin\Mono for Android\chimp\chimp.keystore)

Sign the APK
When Create is clicked, a new key store (containing a new certificate) will be saved and listed under Signing Identity as shown in the next screenshot. To publish an app on Google Play, click Cancel and go to Part 3. To publish ad-hoc, select the signing identity to use for signing and click Save As to publish the app for independent distribution. For example, the chimp signing identity (created earlier) is selected in this screenshot:

Next, the Archive Manager displays the publishing progress. When the publishing process completes, the Save As dialog opens to ask for a location where the generated .APK file is to be stored:

Navigate to the desired location and click Save. If the key password is unknown, the Signing Password dialog will appear to prompt for the password for the selected certificate:

Now you are ready to submit your application to Google Play

3 - SHA-1 fingerprint ?
To Display your SHA-1 Key You can double click on the Signing identity name on your dialog and copy the SHA-1 key hash where you can use it for Google maps integration or for social logins

4 - Reduce the APK size

Users often avoid downloading apps that seem too large, This article describes how to reduce your APK size, which enables more users to download your app.

Step 1 Follow the picture bellow and your Android option should be same as the image bellow 
Dont select the green color frame leave it unchecked 

After selecting Generate Package Per ABI and after archive process is done open your Installed APK folder and you will see as bellow 

Now Your APK is about 36 MB without the Google compressor once you submit it to the google play console it will be 25 MB  till 30 MB.

Step 2 Still you want Smaller ? 😉 
After you open your archive folder you will see the following archives if you selected (Generate Package Per ABI)

Usually you submit the red framed archive as the image bellow which is 36MB
instead of submitting it you can submit 2 APKs to google play by uploading the Archives which are pointed by the red arrow which are 28MB size.


Now your APK file will be from 20 to 25 MB in Google play

5-Improving Startup Times (Splash Screen Loading)

If you use AOT today, it improves startup times drastically, but you suffer in APK size bloat. This, unfortunately, is not a bargain that most Android applications can take in this modern-day as we must keep our users at the forefront of our decisions. They also ensure that they don’t have to download a large APK just to use our services. There must be a better way forward we thought.

We wanted to make sure we address this problem head-on by giving you the best of both worlds; a Performance startup experience, and minimal increase to APK size.
Starting today, we’re announcing faster starter times using Startup Tracing on Android for all versions of Visual Studio 2019.

What is Android AOT?
The Android runtime(ART) is a managed runtime used by applications and system services on Android. ART as the runtime executes Dalvik Executables (.dex files – Dalvik EXecutable) which is a compact format to store Dalvik bytecode.
ART introduced the use of ahead-of-time (AOT) compilation by compiling entire applications into native machine code upon the installation of the application. This brings faster execution of applications and improved memory allocation. As well as garbage collection mechanisms, more accurate profiling, and much more.
To accomplish this, ART uses a utility known as dex2oat (Dalvik Executable to Of Ahead Time) to create an ELF (Executable and Linkable Format) executable. The downside requires additional time to compile. Additionally, applications take up larger amounts of disk memory to store the compiled code.

What is Startup Tracing?
Mono introduced a feature which allows one to use a built-in AOT profiler on an application to generate an AOT profile. The profiler conducts memory profiling, execution time profiling, and even a statistical-based sampling for profiling. This generates an AOT profile that can be used to optimize your application when using Mono’s AOT feature with a profile.



Type Build
Startup Speed
APK Size (Without ABI )
Normal
2s914ms
45.1 MB
AOT
1s18ms
70.6 MB
Startup Tracing
1s518ms
55.1 MB



4 - Reduce the APK size

Users often avoid downloading apps that seem too large, This article describes how to reduce your APK size, which enables more users to download your app.

Step 1 Follow the picture bellow and your Android option should be same as the image bellow 
Dont select the green color frame leave it unchecked 

After selecting Generate Package Per ABI and after archive process is done open your Installed APK folder and you will see as bellow 

Now Your APK is about 45 MB without the Google compressor once you submit it to the google play console it will be 30 MB  till 35 MB.

Step 2 Still you want Smaller ? 😉 
After you open your archive folder you will see the following archives if you selected (Generate Package Per ABI)

Usually you submit the red framed archive as the image bellow which is 45MB
instead of submitting it you can submit 2 APKs to google play by uploading the Archives which are pointed by the green arrow which are 34MB size.


Now your APK file will be from 20 to 25 MB in Google play

5-Improving Startup Times (Splash Screen Loading)

If you use AOT today, it improves startup times drastically, but you suffer in APK size bloat. This, unfortunately, is not a bargain that most Android applications can take in this modern-day as we must keep our users at the forefront of our decisions. They also ensure that they don’t have to download a large APK just to use our services. There must be a better way forward we thought.

We wanted to make sure we address this problem head-on by giving you the best of both worlds; a Performance startup experience, and minimal increase to APK size.
Starting today, we’re announcing faster starter times using Startup Tracing on Android for all versions of Visual Studio 2019.

What is Android AOT?
The Android runtime(ART) is a managed runtime used by applications and system services on Android. ART as the runtime executes Dalvik Executables (.dex files – Dalvik EXecutable) which is a compact format to store Dalvik bytecode.
ART introduced the use of ahead-of-time (AOT) compilation by compiling entire applications into native machine code upon the installation of the application. This brings faster execution of applications and improved memory allocation. As well as garbage collection mechanisms, more accurate profiling, and much more.
To accomplish this, ART uses a utility known as dex2oat (Dalvik Executable to Of Ahead Time) to create an ELF (Executable and Linkable Format) executable. The downside requires additional time to compile. Additionally, applications take up larger amounts of disk memory to store the compiled code.

What is Startup Tracing?
Mono introduced a feature which allows one to use a built-in AOT profiler on an application to generate an AOT profile. The profiler conducts memory profiling, execution time profiling, and even a statistical-based sampling for profiling. This generates an AOT profile that can be used to optimize your application when using Mono’s AOT feature with a profile.



Type Build
Startup Speed
APK Size (Without ABI )
Normal
2s914ms
45.1 MB
AOT
1s18ms
70.6 MB
Startup Tracing
1s518ms
55.1 MB

Push Notification Install 

WoWonder Products are using OneSignal for push notification service.

What is OneSignal?

OneSignal is a high volume and reliable push notification service for websites and mobile applications. They support all major native and mobile platforms by providing dedicated SDKs for each platform, a Restful server API, and an online dashboard for marketers to design and send push notifications.

1. Create a Firebase project

1.1 Visit the Firebase Console and sign in with your Google account.

1.2 Press "CREATE NEW PROJECT" or select an existing one below.

2. Getting your Firebase Cloud Messaging token and Sender ID:

1 Click the Gear icon in the top left and select "Project settings".
2 Select the "CLOUD MESSAGING" tab..

3 Save the two values listed:
  • You'll need your Server key, also known as the Google Server API key.
  • You'll need your Sender ID, also known as the Google Project Number, later as well

3. Configure your OneSignal app's settings

1- Go to App Settings and press the Configure button to the right of Apple IOS.

For Android >> Go to App Settings and press the Configure button to the right of Google Android
2-Paste your Google Server API Key and Google Project Number in here and press Save.

3-Copy your keys from App Settings >> Keys& ids TAB.

4-Pasta all the keys on the (Push Notifications System) Tab on Your Admin Panel ,and select Enable for Push notifications as image bellow and press save .
  1. Then Add the keys on Wowonder >>> OneSignal>> OneSignal_Notifciation.cs

4-Change Your Push Notification Icon


1-From the Solution Explorer go to 
Wowonder >> Resources >> Drawable.

2-Add your image as the same name, it must be >> "ic_stat_onesignal_default.png

5-Change your package name to start getting notifications.


IMPORTANT : Also you need to change your Package name from the AndroidManifest file as bellow >> 

This will activate your One-signal account on your device and you are done.

Frequently Asked Questions (FAQ)


How can i use the API DLL class and write my own code 

We made for our developer few classes which can be accessed anywhere in your project and your own solution 

Our APIs  depends on this 3 variables always which includes website and access token and the secret key as the image bellow.


What Minimum & Maximum Android Target this Application supports?

  • Minimum Android Target is V4.2 . 
  • Maximum Android Target is Version v9 and works on higher versions.

Is this Application Native or Hybrid ?

  • This is full Native application 100% 

How can i modify the style?

  • You can change it from Settings class in your main solution.
  • You can read the Customization section on the doc file

How can i integrate my website with the Application?

  • You can easily integrate it using your Server-key located in your admin panel > Mobile app.
  • Also by adding your website address to the Settings class of the application

Verify Timeline Code on the website control panel is not working ?

  • You can use your purchase key to Verify your application for one time, If you Download application from crackers or illegal websites this application will not work.

Can you install this application for me ?

  • Yes we can , By buying Extended license , We install for free on each new update.
  • Or by paying 25$ for each new install 

How i will know if there is new update for this Application ?

  • Once there is an new update you will get an email send by us with the new update url so you can download and update your app as you like.

How i can have a custom work for this application ?

  • Once You decide to customize your application an change many things or add something new 
     #ScriptSun is your best Freelancing opportunity ,  Turn Your ideas into reality.
     
     Open a custom work ticket Here 
     Website: https://scriptsun.com/
     
 

Can you recommend a hosting company for your scripts ?

If you need a hosting for your item Ultahost.com is the best hosting for your own script