Example #1
0
        public void Update()
        {
            for (int i = 0; i < listHttpLoadHelper.Count; i++)
            {
                HttpLoadHelper loadObj = listHttpLoadHelper[i];
                if (currentDownCount < maxTryCount && loadObj.isStartDown == false)
                {
                    loadObj.StartLoad();
                    currentDownCount++;
                    continue;
                }
                else if (loadObj.isStartDown == false || loadObj.WWWObj == null)
                {
                    continue;
                }
                bool isTimeOut = loadObj.IsTimeOut();
                if (loadObj.isStartDown)
                {
                    if (isTimeOut || !string.IsNullOrEmpty(loadObj.WWWObj.error))
                    {
                        if (isTimeOut)
                        {
                            Debug.Log("Load TimeOut:" + loadObj.WWWObj.url);
                            Log.Print("Load TimeOut:" + loadObj.WWWObj.url);
                        }
                        else
                        {
                            Debug.Log(loadObj.WWWObj.error);
                            Log.Print(loadObj.WWWObj.error + ":" + loadObj.WWWObj.url);
                        }
                        if (loadObj.NeedLoadAgain())
                        {
                            Debug.Log("Load Again:" + loadObj.WWWObj.url);
                            Log.Print("Load Again:" + loadObj.WWWObj.url);
                            loadObj.StartLoad();
                            continue;
                        }
                        else
                        {
                            ErrorHandler(loadObj);
                            loadObj.WWWObj.Dispose();
                            listHttpLoadHelper.RemoveAt(i);
                            currentDownCount--;
                        }
                        continue;
                    }

                    if (loadObj.WWWObj.isDone)
                    {
                        try
                        {
                            if (loadObj.NeedSave)
                            {
                                BytesToFile(loadObj.WWWObj.bytes, loadObj.FileVO.SaveFilePath);
                            }
                            if (loadObj.completeLoadHandler != null)
                            {
                                loadObj.completeLoadHandler(loadObj);
                            }
                            if (loadObj.WWWObj.url.Split('.')[1] == "unity3d")
                            {
                                loadObj.WWWObj.assetBundle.Unload(true);
                            }
                        }
                        catch (Exception ex)
                        {
                            if (loadObj.NeedSave)
                            {
                                Debug.Log("Save File Error:" + loadObj.WWWObj.url + ",Exception:" + ex.ToString());
                                Log.Print("Save File Error:" + loadObj.WWWObj.url + ",Exception:" + ex.ToString());
                            }
                            else
                            {
                                Debug.Log("Down Success But Callback Error:" + loadObj.WWWObj.url + ",Exception:" + ex.ToString());
                                Log.Print("Down Success But Callback Error:" + loadObj.WWWObj.url + ",Exception:" + ex.ToString());
                            }
                        }
                        finally
                        {
                            loadObj.WWWObj.Dispose();
                            listHttpLoadHelper.RemoveAt(i);
                            currentDownCount--;
                            Caching.CleanCache();
                        }
                        return;
                    }
                }
            }
        }