Saturday, December 12, 2015

Joomla: Installing Module throws the "updates" table error

While I was installing a module to the joomla 3.4.X,  I got the below error:

Table 'xxxx_updates' doesn't exist SQL=SHOW FULL COLUMNS FROM `updates` in joomla

And the installation failed. 

It's very easy to solve this issue.

I found that the "xxxx_updates" does not exist in the database Hence we get the above error. To solve this, we can remove this table from the database if exists and then recreate the table with the sql commands mentioned

Here xxxx is the string with the table name. You can replace this with your own string of the database.

To remove the table from table:

DROP TABLE xxxx_updates

To create the new table:

CREATE TABLE IF NOT EXISTS `xxxx_updates` (
  `update_id` int(11) NOT NULL AUTO_INCREMENT,
  `update_site_id` int(11) DEFAULT 0,
  `extension_id` int(11) DEFAULT 0,
  `name` varchar(100) DEFAULT '',
  `description` text NOT NULL,
  `element` varchar(100) DEFAULT '',
  `type` varchar(20) DEFAULT '',
  `folder` varchar(20) DEFAULT '',
  `client_id` tinyint(3) DEFAULT 0,
  `version` varchar(32) DEFAULT '',
  `data` text NOT NULL,
  `detailsurl` text NOT NULL,
  `infourl` text NOT NULL,
  `extra_query` varchar(1000) DEFAULT '',
  PRIMARY KEY (`update_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Available Updates';


This solves the issue. Now try to install the new module And it installs successfully

Wednesday, September 2, 2015

New Android Application- Kids App uploaded to Google Play Store

I was trying to develop an android app for my son which will help him to learn the alphabets. I thought it may be helpful to others also so sharing it in google play - Kids Application .
This is just a draft version and we are planning for more features.

Kids App is a text to speech and image view based project. This application is having its own database, in which I have saved the images, alphabets, words and the pronunciations. As of now I have just added two languages to pronounce and two options to operate this application. 
The languages I have added now are :

                                               1. English
                                               2. Kannada             
We are going to enhance it for other languages also. 

And the two operations are

                                                1. Manual
                                                2. Auto

This application also includes the configuration in settings. In this, user can give images from the camera or the gallery according to his wish. Also user can set the word and the pronunciation data. The whole data will be stored in the database until and unless user selects to set the default data. The core part of code is written in Java, while the GUI is developed using XML.

Once you open the application, the logo of the company is shown as the splash screen. And then the user is asked to select mode and language as below:


 


You can select English Language and Manual Mode, You will see the below screen:



You can press any alphabets, application shows the word for it with the respective image and also it pronounces the word (text to speech): For eg: A for Apple. Look at the below image:


It has numbers also for the pronunciation and view as below:



The best part of this application is user can configure his own word, image and pronunciation for the alphabets. For Example, if user's son's name is  Krishna, he can set the this name, his image and pronunciation for Letter K.  For that user has to click on menu button in the above screen and select configure :


 

User can set it. And henceforth if user click on that set alphabet, user gets the configured image, word and pronunciation.  Anytime, user can change them. If user wants to set them to default, he can click on the "SetDefault" so that user get the default words, images and pronunciation.

If user select the mode as "Auto", application automatically walks through all the alphabets and numbers without user selections of any buttons.



Similarly user can use other languages also. Now we have added it for Kannada only. Later we will add for other languages



Same operations as in English,  can be done for Kannada also:

 

We have plans to add lot of other features to it. Keep watching this for more updates
You can download it from google play: Kids App

 Kids app


Tuesday, August 25, 2015

How to Enable or Disable a button in runtime in Android

While I was working with an Android application for a customer, there was a use case to disable a button in the run time. And need to enable it after some action. We can do it very easily in Android.


I have a “About” button in the screen. And I need to enable and disable the button based on the network status. In xml, we have the button as below:

<Button
        android:id="@+id/about_button"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="64dp"
        android:text="@string/about_label" />     

You need to reference it in the activity using findViewById in onCreate() method:

View aboutButton = findViewById(R.id.about_button);

You can enable or disable by setting  setEnabled() to true or false.

To enable: setEnabled(true);
And to disable: setEnabled(false);

aboutButton.setEnabled(false);

Now, I am going to enable it if the connectivity is available. I have added a class- NetworkUtil to check the network status. You can download it from here. (NetworkUtil) and use it in your activity to check the status. You need to create an object for this class and use the method: getConnectivityStatus. Here is the code to do so:

NetworkUtil net =new NetworkUtil();
      int status = net.getConnectivityStatus(getApplicationContext());
        if(status!=0){
            aboutButton.setEnabled(true);
        }
        else{
            aboutButton.setEnabled(flase);
     
          }                 

That’s it. Happy Coding..



Saturday, August 22, 2015

How to know if AdMob ad has been loaded in your Android Application

In my last blog we have discussed about adding an ad from Admob network. This is in continuation with that.


In the applications we may need to take some action if the ad is loaded and some other action if the ad is not loaded. In such cases it’s very much important to know if the Admob ad is loaded to our application or not. We can achieve using the setAdListener interface of AdView. Below is the code which can be used to achieve this:

ad.setAdListener(new AdListener() {                 
              @Override
              public void onAdLoaded() {
                    Log.d(TAG, "Ad Received");
                    //Code implementation if the ad is loaded
                       ………
                      ………
                  }
               @Override
               public void onAdFailedToLoad(int errorcode) {
                      Log.d(TAG, "Ad Not Loaded Received");
                 //Code implementation if the ad is NOT loaded
                   ………
                 ………
               }
             });

onAdLoaded is the method which is used to check if the ad is loaded. And
onAdFailedToLoad is the method used to check if the ad is not loaded. Based on these implementation you can implement your respective action code.

Also you need to fetch the ads only if you have the network connectivity otherwise it just keeps trying to fetch the ad which may slow your application. We can check the network status before we fetch and load the ads. To check the network status you can use ConnectivityManager class. 

private static final String DEBUG_TAG = "NetworkStatusExample";

...      

ConnectivityManager connMgr = (ConnectivityManager) 

        getSystemService(Context.CONNECTIVITY_SERVICE);

NetworkInfo networkInfo = connMgr.getNetworkInfo(ConnectivityManager.TYPE_WIFI); 

boolean isWifiConn = networkInfo.isConnected();

networkInfo = connMgr.getNetworkInfo(ConnectivityManager.TYPE_MOBILE);

boolean isMobileConn = networkInfo.isConnected();

Log.d(DEBUG_TAG, "Wifi connected: " + isWifiConn);

Log.d(DEBUG_TAG, "Mobile connected: " + isMobileConn);

For this I have added a class- NetworkUtil to check the network status. You can download it from here. (NetworkUtil) and use it in your activity to check the status. You need to create an object for this class and use the method: getConnectivityStatus. Here is the code to do so:

NetworkUtil net =new NetworkUtil();
       int status = net.getConnectivityStatus(getApplicationContext());
        if(status!=0){
            //Code if the network connection is there      
        }
        else{
            //Code if the network connection is NOT there     
          }

The final code looks like this:

      NetworkUtil net =new NetworkUtil();
        AdView ad=(AdView)findViewById(R.id.adView);        
        int status = net.getConnectivityStatus(getApplicationContext());
        if(status!=0){
            ad.loadAd(new AdRequest.Builder().build());
           ad.setAdListener(new AdListener() {
                 @Override
                  public void onAdLoaded() {
                           Log.d(TAG, "Ad Received");
                           //code when the ad loaded
                  }
                 @Override
                  public void onAdFailedToLoad(int errorcode) {
                           Log.d(TAG, "Ad Not Loaded Received");
                           //code if the ad loading is failed
                  }
           });            
        }
       else{
                  //Code if the network connection is NOT there                
        }

That’s it. Happy Coding..

Friday, August 21, 2015

Integrating Google AdMob Ads in Android Application

I was wondering how to integrate Advertises from google in my Android applications. AdMob is the best mobile advertising site which you can integrate with your Android Application very easily.
In this blog, you learn how to show AndMob Advertises in your Android Application.  This write up is divided into below three parts: 

1.     Getting Ad Unit Id from Admob Site
2.     Installing Google Play Services in Android SDK
3.     Integrating AdSense code to Android App.

1)     Getting Ad Unit Id from Admob Site :

1.     Go to AdMob Site

2.     Create New Account (if you are already an admob user, then log in)

3.     Select "Monetize new app" option.


4.   Search your android application for which you want to integrate the Admob. You can search it in Google Play or you can add the details about the application.



       5. After filling all information, you get the instructions to set up admob unit id.


6. Now, your app is added to the admob site. You can check this in all apps list in Monetize tab of        this site. You can select this app and create the ad banner and get the ad unit id which looks as:
ca-app-pub-50xxxx69xxxxxxxx/34xxxxxxxx

7.  You need to use this Ad Unit Id in our project later.


2)     Installing Google Play Services in Android SDK


1.     Open the Eclipse and Go to Windows-&gt;SDK Manager :



2.  In the packages select Extras-&gt;Check Google Play Services and install it as shown below: 


3.    Import the Google play Services to you Workspace.

4.   Now Go to your project where you want to integrate this admob, and add this Google play services library to this project: 




3)     Integrating AdSense code to Android App:

     1.  Open your android XML file and add the following line in layout:

xmlns:ads=http://schemas.android.com/apk/res-auto      
  
2.     Add AdView in Layout:

<com.google.android.gms.ads.AdView
 android:id="@+id/adView"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 ads:adSize="BANNER"
 ads:adUnitId="YOUR_AD_UNIT_ID"

/>

3.    Now open your Java file and initialize AdView Object in your Activity:
AdView ad=(AdView)findViewById(R.id.adView);
     4.   Load Ad from Google:
ad.loadAd(new AdRequest.Builder().build());
5.  Now modify the AndroidManifest.xml:

      a.      Add Permissions: 

<!-- Used to request banner ads. -->
<uses-permission android:name="android.permission.INTERNET" />

<!-- Used to avoid sending an ad request if there is no connectivity. -->

<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

     b.     Need to add metadata of Google play Services: 

<meta-data
 android:name="com.google.android.gms.version"

 android:value="@integer/google_play_services_version" />

           
     c.    Need to add the below activity to show the ad overlays:

<activity
 android:name="com.google.android.gms.ads.AdActivity"

  android:configChanges="keyboard|keyboardHidden|orientation|screenLayout|uiMode|screenSize|smallestScreenSize"/>

  d.      Final AndroidManifest.xml looks as below:
xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.marutsoft.sudoku"
      android:versionCode="3"
      android:versionName="1.3">
    <uses-sdk android:minSdkVersion="7"
        android:targetSdkVersion="19"/>
    <!-- Used to request banner ads. -->
<uses-permission android:name="android.permission.INTERNET" />
<!-- Used to avoid sending an ad request if there is no connectivity. -->
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

<application android:icon="@drawable/icon" android:label="@string/app_name">
        <meta-data
 android:name="com.google.android.gms.version"
 android:value="@integer/google_play_services_version" />

         <activity android:name="com.marutsoft.sudoku.Splash"
                  android:label="@string/app_name">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
          
        <!-- Activity required to show ad overlays. -->
<activity
 android:name="com.google.android.gms.ads.AdActivity"
 android:configChanges="keyboard|keyboardHidden|orientation|screenLayout|uiMode|screenSize|smallestScreenSize" />
            
    </application>

</manifest>
   
Now run your application and check that google adverise is shown in the activity where you have added it. Please note you need to have the internet connectivity.

Also you can add the code to check the availability of the connectivity and then load the advertise. We will add that part in my next blog

That’s it. Happy Coding..