如何进行超级课程,我可以打电话来处理我的下载内容

马克·哈罗普

我真的很难使用我的Dropbox API。
我想在一个超级类中使用它,我可以从其他类中调用它。
让我感到困惑的是,我不知道如何正确设置它。
我已经上了全班,并宣布它是超一流。
我已经获取了所有API信息,但是我需要能够从其他活动中选择文件夹的名称和文件名。
即:我有一个名为启动器的部分,该部分有7个下载选项。然后我有另一个Activity,带有3个下载,称为anima,我想使用相同的API,只是更改目录和路径。
另外,我又如何从另一个活动中调用它呢?

public class HarropDropBoxApi extends Activity {

    public static String APP_TYPE = "I want to name this from other classes??";
    public static String APK_NAME = "I want to name this depending on the item in my list view in other classes ";
    public static String path = Environment.getExternalStorageDirectory().getAbsolutePath() + APP_TYPE;
    public static File Dir = new File(path);
    AndroidAuthSession session = buildSession();


    static DropboxAPI<AndroidAuthSession> dropboxAPI;
    private final String APP_KEY = "my-app-key";
    private final String APP_ACCESS = "my-access-key";
    private final String TOKEN = "my-token";
    private DropboxAPI.UploadRequest request;

    public HarropDropBoxApi() {


    }

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        Dir.mkdir();

        dropboxAPI = new DropboxAPI<AndroidAuthSession>(session);
        //below was how i was calling the api for a single App Type and Apk name
        //DownloadFromDropboxFromPath(path + "downloadFileFromDropbox", "CastingApps/AllCast.apk");

        /// This line ive changed to match my strings above to be called from other classes/activities will this work?
        // Also this line is where the file is downloaded to and from so does this line get called from here or from my activities??
        DownloadFromDropboxFromPath(path + "downloadFileFromDropbox", APP_TYPE + APK_NAME );

    }

    private AndroidAuthSession buildSession() {
        AppKeyPair appKeyPair = new AppKeyPair(APP_KEY, APP_ACCESS);
        AndroidAuthSession session = new AndroidAuthSession(appKeyPair);
        session.setOAuth2AccessToken(TOKEN);
        return session;
    }

    public static String DropboxDownloadPathFrom = "";
    public static String DropboxDownloadPathTo = "";

    private void DownloadFromDropboxFromPath(String downloadPathTo, final String downloadPathFrom) {
        DropboxDownloadPathTo = downloadPathTo;
        DropboxDownloadPathFrom = downloadPathFrom;

        runOnUiThread(new Runnable() {
            @Override
            public void run() {

                Toast.makeText(getApplicationContext(), "Downloading  Please wait ...", Toast.LENGTH_LONG).show();
                Thread th = new Thread(new Runnable() {
                    public void run() {
                        final File file = new File(DropboxDownloadPathTo + DropboxDownloadPathFrom.substring(DropboxDownloadPathFrom.lastIndexOf('.')));
                        if (file.exists()) file.delete();


                        try {
                            FileOutputStream outputStream = new FileOutputStream(file);
                            HarropDropBoxApi.dropboxAPI.getFile(DropboxDownloadPathFrom, null, outputStream, null);
                            getMain().runOnUiThread(new Runnable() {
                                @Override
                                public void run() {
                                    Toast.makeText(getApplicationContext(), "File successfully downloaded.", Toast.LENGTH_SHORT).show();





                                    Intent promptInstall = new Intent(Intent.ACTION_VIEW).setDataAndType(Uri.fromFile(file),
                                            "application/vnd.android.package-archive");
                                    promptInstall.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);

                                    startActivity(promptInstall);

                                }
                            });
                        } catch (Exception e) {
                            e.printStackTrace();
                        }

                    }
                });
                th.start();
            }
        });
    }


    public HarropDropBoxApi getMain() {
        return this;
    }
}
板球运动员

由于我没有使用Dropbox API,因此无需进行测试就将其组合在一起,但是逻辑对我来说似乎很好。

首先,对后台操作使用AsyncTask,而不是低级Thread这里要注意的事情:

  1. 给出一个Context参数(如Activity),期望将硬编码的字符串移出Java代码并移至某些资源文件中。
  2. 添加了接口回调,以便您可以将结果返回执行该任务的位置。如果不调用setOnDownloadListener,该文件将下载,但结果不会发生任何事情。
  3. (附加说明):您似乎可以对始终存在的目录进行硬编码;无需指定“下载到”目录。
public class DropboxDownloadTask extends AsyncTask<String, Void, File> {

    public interface OnDropboxDownloadListener {
        void onSuccess(File dropboxFile);
    }

    private static final String APP_KEY = "my-app-key";
    private static final String APP_ACCESS = "my-access-key";
    private static final String TOKEN = "my-token";

    // TODO: See below
    // private final String appKey, appAccess, dropboxToken;

    private final Context context;
    private final AndroidAuthSession session;
    private final DropboxAPI<AndroidAuthSession> dropboxAPI;

    private OnDropboxDownloadListener listener;

    public DropboxDownloadTask(Context c) {
        this.context = c;

        // TODO: Move those strings to a string resource file
        /*
        appKey = c.getResources().getString(R.string.dropbox_app_key);
        appAccess = c.getResources().getString(R.string.dropbox_access_key);
        dropboxToken = c.getResources().getString(R.string.dropbox_token);
        */

        session = buildSession();
        dropboxAPI = new DropboxAPI<AndroidAuthSession>(session);
    }

    public void setOnDownloadListener(OnDropboxDownloadListener listener) {
        this.listener = listener;
    }

    private AndroidAuthSession buildSession() {
        AppKeyPair appKeyPair = new AppKeyPair(APP_KEY, APP_ACCESS);
        AndroidAuthSession session = new AndroidAuthSession(appKeyPair);
        session.setOAuth2AccessToken(TOKEN);
        return session;
    }

    @Override
    protected File doInBackground(String... params) {
        File file;
        if (params.length != 2) {
            throw new IllegalArgumentException("Must give Dropbox to and from paths!");
        }
        String downloadPathTo = params[0];
        String downloadPathFrom = params[1];

        file = new File(downloadPathTo + downloadPathFrom.substring(downloadPathFrom.lastIndexOf('.')));
        if (file.exists()) file.delete();

        try {
            FileOutputStream outputStream = new FileOutputStream(file);
            dropboxAPI.getFile(downloadPathFrom, null, outputStream, null);
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }

        return file;
    }

    @Override
    protected void onPostExecute(File result) {
        if (this.listener != null) {
            this.listener.onSuccess(result);
        }
    }
}

有了这个功能之后,您就可以在任何有Context引用的地方使用并可以实现了OnDropboxDownloadListener您的问题尚不清楚,为什么要扩展一个Activity类,但是如果您要使用一个Activity,它可能看起来像这样。

public class MainActivity extends Activity implements DropboxDownloadTask.OnDropboxDownloadListener {

    private DropboxDownloadTask dropboxDownloadTask;

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

        // pass the context 
        dropboxDownloadTask = new DropboxDownloadTask(this);
        // pass the listener 
        dropboxDownloadTask.setOnDownloadListener(this);

        // TODO: Implement 
        downloadFromDropbox("to", "from");

    }

    private void downloadFromDropbox(String downloadPathTo, final String downloadPathFrom) {
        Toast.makeText(getApplicationContext(), "Downloading  Please wait ...", Toast.LENGTH_LONG).show();
        dropboxDownloadTask.execute(downloadPathFrom, downloadPathTo);
    }

    @Override
    public void onSuccess(File dropboxFile) {
        Toast.makeText(getApplicationContext(), "File successfully downloaded.", Toast.LENGTH_SHORT).show();

        Intent promptInstall = new Intent(Intent.ACTION_VIEW)
                .setDataAndType(Uri.fromFile(dropboxFile), "application/vnd.android.package-archive");
        promptInstall.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);

        startActivity(promptInstall);
    }
}

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

我打电话的EntityManager的NullReferenceException

谁在打电话给我的HttpServletRequest?

去)我如何进行下载服务?

如何处理我的PATH变量中的重复项?

我需要数据库来处理我的网站内容吗?

有没有更可维护的方式来处理我的数据类型?

为什么href无法处理我的内容?

在哪里打电话,以便我可以处理异常情况?

如何处理我的Google助理技能中的“拒绝”?

不会让我在课外打电话

我可以通过我的应用程序(Flutter Android和IOS)直接拨打电话吗?

我的BroadcastReceiver不会打电话

发现了这个但不确定如何打电话所以我可以去

如何处理我未分配的内存

如何正确处理我的servlet中的异常

创建一个函数来处理我的数据框计算

如何处理我的错误?

DataStax OpsCenter如何处理我的AWS凭证?

如何进行改造课程

雄辩的自我加入-如何打电话

我可以打电话给特定的世代GC吗

如何处理我的JavaScript作业?

如何使用Lodash和Normalizr处理我的redux商店?

Mozilla Thunderbird 如何处理我的密钥,是否可以直接从 gpg 密钥环导入?

如何快速创建一个 Network 类来处理我所有的数据库 Firestore 操作并且可以从任何视图控制器调用?

如何在实体框架核心 2.2 中创建类库 proejct 来处理我的迁移和数据库对象?

如何使用 Javascript 管理我的 json 内容

是否有单个 SQL 更新语句来处理我的场景?

如何预处理我的 Mapdataset 以适合我的模型输入?