3

I'm trying to make my app download an expansion file. Here's my main:

package tm.down.rob;

import com.google.android.vending.expansion.downloader.DownloadProgressInfo;
import com.google.android.vending.expansion.downloader.DownloaderClientMarshaller;
import com.google.android.vending.expansion.downloader.Helpers;
import com.google.android.vending.expansion.downloader.IDownloaderClient;

import android.app.Activity;
import android.app.PendingIntent;
import android.content.Intent;
import android.os.Bundle;
import android.os.Messenger;
import android.util.Log;
import android.widget.ProgressBar;
import android.widget.TextView;

public class main extends Activity implements IDownloaderClient {
    /** Called when the activity is first created. */

    TextView tv1;

    @Override
     public void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.main);

      //////////
      tv1 = (TextView)findViewById(R.id.textView1);
      //////////

      // Check whether the file have been downloaded.
      String mainFileName = Helpers.getExpansionAPKFileName(this, true, 1);
      boolean fileExists = Helpers.doesFileExist(this, mainFileName, 32921796L, false);

      if (!fileExists) {
       Intent launcher = getIntent();
       Intent fromNotification = new Intent(this, getClass());
       fromNotification.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TOP);
       fromNotification.setAction(launcher.getAction());

       if (launcher.getCategories() != null) {
        for (String cat : launcher.getCategories()) {
         fromNotification.addCategory(cat);
        }
       }

       PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, fromNotification, PendingIntent.FLAG_UPDATE_CURRENT);

       try {

        int result = DownloaderClientMarshaller.startDownloadServiceIfRequired( this, pendingIntent, ExpansionFileDownloaderService.class);
        if (DownloaderClientMarshaller.NO_DOWNLOAD_REQUIRED != result) {

            // implement Downloading UI.
            tv1.setText("Need to download.");

         return;
        }

       } catch (Exception e) { 
        Log.e("apk-expansion-files", "NameNotFoundException occurred. " + e.getMessage(), e);
       }
      }

      tv1.setText("Downloaded!");

     }


    ///////////////////////////////////////////////////


    @Override
    public void onServiceConnected(Messenger m) {
        tv1.setText("onServiceConnected: " + m.toString() );
    }

    ///////////

    @Override
    public void onDownloadStateChanged(int newState) {
        tv1.setText("onDownloadStateChanged: " + String.valueOf(newState) );
    }

    ////////////

    @Override
    public void onDownloadProgress(DownloadProgressInfo progress) {
        ProgressBar mPB = (ProgressBar)findViewById(R.id.progressBar1);

        progress.mOverallTotal = progress.mOverallTotal;
        mPB.setMax((int) (progress.mOverallTotal >> 8));
        mPB.setProgress((int) (progress.mOverallProgress >> 8));
        //mProgressPercent.setText(Long.toString(progress.mOverallProgress * 100 / progress.mOverallTotal) + "%");
        //mProgressFraction.setText(Helpers.getDownloadProgressString(progress.mOverallProgress,progress.mOverallTotal));

    }

    ////////////




}

I compiled the apk and uploaded it to the marker with a zip file renamed to main.1.tm.down.rob.obb but still, when I run my app, it throws me "Download failed because the resource could not be found"...

Any ideas? Thanks!

Roger Travis
  • 8,402
  • 18
  • 67
  • 94

1 Answers1

0

I had the same issue when I was trying to use downloader library apklib+jar deployed to my Maven repository using https://github.com/mosabua/maven-android-sdk-deployer

When I've re-deployed the downloader library to my Maven repository using this Gradle build script:

buildscript {
  repositories {
    mavenCentral()
  }

  dependencies {
    classpath 'com.android.tools.build:gradle:0.11.+'
  }
}

apply plugin: 'android-library'
apply plugin: 'maven'

repositories {
  maven {
    url "http://repository_url/nexus/content/repositories/release"
  }
  maven {
    url "http://repository_url/nexus/content/repositories/release/"
  }
  mavenCentral()
}

dependencies {
  compile 'com.google.android.licensing:play-licensing:2.+@aar'
}

android {
  compileSdkVersion 19
  buildToolsVersion '19.1'

  sourceSets {
    main {
      assets.srcDirs       = ['assets']
      res.srcDirs          = ['res']
      aidl.srcDirs         = ['src']
      resources.srcDirs    = ['src']
      renderscript.srcDirs = ['src']
      java.srcDirs         = ['src']
      manifest.srcFile 'AndroidManifest.xml'
    }
  }
}

uploadArchives {
  repositories {
    mavenDeployer {
      repository(url: "http://repository_url/nexus/content/repositories/release/") {
        authentication(userName: "user", password: "password")
      }

      pom.version = "3.0.0"
      pom.artifactId = "play-apk-expansion-downloader"
      pom.groupId = "com.google.android.apk.expansion"
    }
  }
}

and changed dependency to AAR package:

dependencies {
  compile 'com.google.android.apk.expansion:play-apk-expansion-downloader:3.+@aar'
}

it started to work.

Blackhex
  • 1,694
  • 3
  • 21
  • 45