Esempio n. 1
0
        /// <summary>
        /// instantiate an entity
        /// </summary>
        /// <returns>The entity.</returns>
        /// <typeparam name="T">The 1st type parameter.</typeparam>
        public static T InstanceEntity <T>() where T : EntityObject, new()
        {
            EntityObject obj         = null;
            bool         useRecycler = true;

            //search in recycler first
            Type type = typeof(T);

            obj = objRecycler.Pop(type.FullName) as EntityObject;
            if (obj == null)
            {
                useRecycler = false;
                obj         = new T();
            }
            obj.InstanceInFactory();

            objectList.Add(obj);

            if (EnableLog && MyLogger.EnableLog)
            {
                MyLogger.Log(LOG_TAG, "InstanceEntity() {0}:{1}, UseRecycler:{2}", obj.GetType().Name, obj.GetHashCode(), useRecycler);
            }

            return((T)obj);
        }
Esempio n. 2
0
        public static void CreateView(string resPath, string resDefaultPath, EntityObject entity, Transform parent = null)
        {
            ViewObject obj         = null;
            string     recycleType = resPath;
            bool       useRecycler = true;

            obj = objRecycler.Pop(recycleType) as ViewObject;
            if (obj == null)
            {
                useRecycler = false;
                obj         = InstanceViewFromPrefab(recycleType, resDefaultPath);
            }

            if (obj != null)
            {
                if (!obj.gameObject.activeSelf)
                {
                    obj.gameObject.SetActive(true);
                }

                if (parent != null)
                {
                    obj.transform.SetParent(parent, false);
                }
                else
                {
                    obj.transform.SetParent(viewRoot, false);
                }

                obj.CreateInFactory(entity, recycleType);

                if (EnableLog && MyLogger.EnableLog)
                {
                    MyLogger.Log(LOG_TAG, "CreateView() {0}:{1} -> {2}:{3}, UseRecycler:{4}",
                                 entity.GetType().Name, entity.GetHashCode(),
                                 obj.GetRecycleType(), obj.GetInstanceID(),
                                 useRecycler);
                }

                if (mapObjectList.ContainsKey(entity))
                {
                    MyLogger.LogError(LOG_TAG, "CreateView()", " Mapping already exist!");
                }
                mapObjectList[entity] = obj;
            }
        }