IronSource, unity 2020.3.21f1 기준, android
- 리워드 광고 비디오 보기 후 이전에 광고 볼때의 화면이 나타나고 멈추어 있음
- UnityPlayerActivity resume 이 안되는것 같음
- 이것저것 다해봤지만(2019 -> 2020 업데이트등..) 안됨
- 원인은 광고 activity 가 나오기 전에 Handheld.StartActivityIndicator(); 로 인디게이터 돌려주는게 원인.
- 제거하니 문제 발생 안함.
- 광고activity 가 종료되면서 뭔가 activtiy 가 꼬이는듯.
'Dev > Unity3D' 카테고리의 다른 글
E/Unity: AndroidVideoMedia::VideoDecoder::Blit failed. Decode shader probably unsupported. (0) | 2021.11.06 |
---|---|
StreamingAsset 활용하기. (0) | 2012.06.18 |
Texture, Resource.... and Memory!! (1) | 2012.06.05 |
GameObject active 여부와 Coroutine / Invoke... (1) | 2012.06.05 |
Unity, Audio, and Memory (0) | 2012.01.25 |
Graphics Setting 의 Always included shaders 에 아래 포함
Hidden/VideoDecode
Hidden/VideoDecodeAndroid
Unity 2020.3.21f1 기준으로
Video 항목이 새로 생귐 = Always include
- Always included shaders 에 안해도 될것 같지만 귀찮아서 안해봄
batchmode 에서는 여전히 안됨
- -nographics 옵션을 뺴고 하면 잘됨.(MAC 빌드 기준)
'Dev > Unity3D' 카테고리의 다른 글
리워드광고 보기 후 유니티 화면 멈춤 (0) | 2021.11.08 |
---|---|
StreamingAsset 활용하기. (0) | 2012.06.18 |
Texture, Resource.... and Memory!! (1) | 2012.06.05 |
GameObject active 여부와 Coroutine / Invoke... (1) | 2012.06.05 |
Unity, Audio, and Memory (0) | 2012.01.25 |
- 서버에서 다운받는 데이터를 아직 서버가 마련되지 않아 파일형식으로 유니티에 포함시킬때 사용.
- Assets/StreamingAssets/ 폴더에 넣어두면 된다.
- 위치
Standalone
- path = = Application.dataPath + "/StreamingAssets";
iOS
- path = Application.dataPath + "/Raw";
Android
- path = "jar:file://" + Application.dataPath + "!/assets/";
- WWW 는 사용하지 못한다..jar 를 열수 있는 다른 것을 사용한 후에 사용가능.
'Dev > Unity3D' 카테고리의 다른 글
리워드광고 보기 후 유니티 화면 멈춤 (0) | 2021.11.08 |
---|---|
E/Unity: AndroidVideoMedia::VideoDecoder::Blit failed. Decode shader probably unsupported. (0) | 2021.11.06 |
Texture, Resource.... and Memory!! (1) | 2012.06.05 |
GameObject active 여부와 Coroutine / Invoke... (1) | 2012.06.05 |
Unity, Audio, and Memory (0) | 2012.01.25 |
* Memory 해제 관련...
*. Prefab 을 public GameObject variable 로 연결하면 1개가 살아있다...
- Resource 로 옮기고 Resource.Load 후 Instantiate 해준다음 Resource.UnloadUnusedAsset으로 로드했던 prefab을 해제시키자.
* Texture
- WWW 혹은 다른곳에서 load 한 texture 들은 사용하지 않을때 DestroyImmediate 로 꼭 해제시켜줘야 한다. DestroyImmediate 해주면 바로 memory 에서 해제된다.
*. GameObject Destroy 는 memory 를 바로 해제시키지 않는다.
- Resource.UnloadUnusedAssets 를 해야 memory 에서 해제된다.
- GameObject 를 DestroyImmediate 해도 포함되있는 Texture, material, 등은 memory에서 해제되지 않는다.
*. Load 한 Texture 들을 Member 로 가지고 있으면 GameObject Destroy 시 memory 해제 안된다.
- Texture 는 개별 DestroyImmediate 하여 바로바로 해제하자.
'Dev > Unity3D' 카테고리의 다른 글
E/Unity: AndroidVideoMedia::VideoDecoder::Blit failed. Decode shader probably unsupported. (0) | 2021.11.06 |
---|---|
StreamingAsset 활용하기. (0) | 2012.06.18 |
GameObject active 여부와 Coroutine / Invoke... (1) | 2012.06.05 |
Unity, Audio, and Memory (0) | 2012.01.25 |
unity3d data path! (0) | 2011.12.14 |
GameObject.active = true;
- StartCoroutine : OK
- Coroutine Method : OK
- StopAllCoroutine : OK
- Invoke : OK
- InvokeRepeating : OK
- CancelInvoke : OK
GameObject.active = false;
- StartCoroutine : Error
- Coroutine Method : Stop (active 상태에서 돌고 있는 상태였다면 정지된다.)
- StopAllCoroutine : OK
- Invoke : OK
- InvokeRepeating : OK
- CancelInvoke : OK
** 결론
- StartCoroutine 으로 코루틴 메소드를 열심히 돌리다가 해당 GameObject 의 active 가 꺼지면 돌던 코루틴 메소드는 정지되고 다시 active 가 켜지더라도 재실행되지 않는다.....
- 코루틴을 많이 사용하는 로직(Async 로 돌리는 함수들..(WWW, ... 같은...))에서는 꼭 염두해 두어야 한다..
- OnDisable() {} 에서 관련 처리를 해 주는게 좋다.
- Invoke 관련은 GameObject 의 active 유무랑 관계없이 돌아간다..
'Dev > Unity3D' 카테고리의 다른 글
StreamingAsset 활용하기. (0) | 2012.06.18 |
---|---|
Texture, Resource.... and Memory!! (1) | 2012.06.05 |
Unity, Audio, and Memory (0) | 2012.01.25 |
unity3d data path! (0) | 2011.12.14 |
Unity3D Mesh Create Code (0) | 2011.10.20 |
The project I am currently programming audio for targets low end machines. I spent many many hours google and forum searching trying to find definitive answers to how Audio works, especially when related to how it consumes memory and how I can release that memory when the audio is no longer needed. Hopefully the following information will save you loads of time.
Hierarchy and Audio Memory
Any AudioClips that are referenced in the hierarchy of a scene will be
loaded in to memory when the scene gets loaded. Keep this in mind if you
have a large audio library and are throwing a huge prefab of all your
sounds into the scene hierarchy (nom nom memory nom nom). The only way
to avoid this is to load audio dynamically with scripts.
Objects and Garbage Collection
Unity keeps track of anything you create that extends from their Object
class. That means a couple things. If you do reference one of those
objects and set that reference to null, the garbage collector WILL NOT
pick it up. The reason for this is that the object still has references
in Unity. If you want to release memory for Unity Objects you must call
Destroy and pass the object as a parameter. Why is this important?
AudioClips extend from Object. Hence setting them to null will not
release them from memory.
Resources.Load
Resources.Load creates an object in memory and returns a reference to
it. That object is actually the physical asset in your library which is
loaded from a .asset file. This file is created when you build.
If you call Destroy on the resource inside the editor you will get a warning that it will delete the actual asset itself. The editor protects you against doing this, but the build will actually delete the asset (but not permanently – more testing required to confirm full behavior). DestroyImmediate will destroy the asset without warning, so be careful when using it. If you are in the editor and that happens you will have to reimport your asset.
The only way to release the memory held by the resource is to call Resources.UnloadUnusedAssets(). This process isn’t the fastest, so doing it during an Update can hurt your performance.
One of the strongest advantages to using Resources.Load is that multiple copies of your AudioClip do not increase your memory size. You can play your clip with 8 different sources and all 8 will play individually and fully layered without adding more AudioClips to memory. The main disadvantage is that if you need to free up memory that an asset occupies, you really can’t be specific and must run the bulky Resources.UnloadUnusedAssets function.
Note that you cannot instantiate an asset object in the build. The editor will allow you to do this however, which is unfortunately very misleading.
Asset Bundles
Asset bundles behave exactly like Resources.Load. Think of them as a way
to fragment the .asset file into .unity3d files. This is especially
powerful for the web player since you can prioritize which assets get
downloaded by the user. Asset bundles need to be loaded with the WWW
class. Just like Resources.Load, you will receive an actual asset so
destroying them to release memory is not an option. You can however be
more specific when unloading them compared to
Resources.UnloadUnusedAssets.
WWW
WWW.audioClip does not return a reference to an AudioClip. In fact, it
creates an entirely new clip object. The documentation does state that
the returned AudioClip is “generated”, but let’s explore the
implications of that statement. Note that WWW.GetAudioClip() does the
exact same thing except is allows you to specify whether the sound is 3D
or 2D.
You can see that new clips are generated by running the following script:
WWW www = new WWW(urltosound); AudioClip clip; for ( int i = 0; i < 20; i++) { clip = www.audioClip; } Debug.Log( "AudioClips " + FindObjectsOfTypeAll(typeof(AudioClip)).Length); |
You will see that 20 AudioClips are created. That creates a huge problem. These clips will reside in memory until they are destroyed. You can do that manually if you have a reference or if you don’t, by calling Resources.UnloadUnusedAssets(). Note that UnloadUnusedAssets will look through the entire game hierarchy and scripts to make sure there are no references to the resources. This IS slow so avoid putting in places where it will be called often (Update for example).
Based on testing 3.3.0f4 and recent forum postings, you can not stream audio in the standalone player with the WWW class using WWW.GetAudioClip() and WWW.audioClip. Both return unplayable sounds until the file has been fully loaded. You can however stream Ogg files using WWW.oggVorbis (which sadly is not documented).
WWW variables DO take up memory space. Since they do not extend from a Unity Object, you can release them from memory by setting them to null.
Unlike Resources.Load, AudioClips you get from WWW do not automatically layer. In other words, if you play the clip with 8 sources, you will only hear one instance of your AudioClip (restarts to the beginning with each call to Play). So for each instance you want, you must create a new clip for it. You can do this with Instantiate(), but with one caveat: PlayOneShot() will return a channel error. That means that you must manually handle the creation and destruction of your AudioSources when using sounds created from WWW. If you do wish to use PlayOneShot(), you can instead create your copies by keeping the WWW in memory and calling WWW.audioClip or WWW.GetAudioClip().
PlayOneShot
PlayOneShot automatically creates an AudioSource for you and destroys
it. However, what it does not do is destroy the AudioClip that you pass
it. Hence you could get a huge memory leak if you pass it www.audioClip
since it will create an un-referenced AudioClip object each time you
PlayOneShot.
AudioSource
AudioSource.clip is a reference to an AudioClip. So you can destroy the
AudioClip by running Destroy(AudioSource.clip). If you have another
reference to the destroyed clip it will become null. Destroying an
AudioSource DOES NOT destroy the AudioClip it references. This is
significant if you are using AudioSources to store you AudioClips. You
must destroy the AudioClip before you destroy the AudioSource if you
want all related memory to get released.
Original : http://www.alexander-fisher.com/?p=351
'Dev > Unity3D' 카테고리의 다른 글
Texture, Resource.... and Memory!! (1) | 2012.06.05 |
---|---|
GameObject active 여부와 Coroutine / Invoke... (1) | 2012.06.05 |
unity3d data path! (0) | 2011.12.14 |
Unity3D Mesh Create Code (0) | 2011.10.20 |
Unity3D Inspector object 선택후 일괄 처리 (0) | 2011.07.02 |
- Application.dataPath /*project*/Assets
// ** iPhone device
- Application.dataPath /var/mobile/Applications/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX/Assets
- Application.persistentDataPath : /var/mobile/Applications/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX/Documents
- Application.temporaryCachePath : /var/mobile/Applications/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX/Library/Caches
- iPhpone Simulator Path : /Users/<Name>/Library/Application Support/iPhone Simulator/4.1/Applications/<GUID>/
// ** Android
- Application.dataPath /mnt/asec/com.xxx.xxx/pkg.apk
- Application.persistentDataPath /data/data/com.xxx.xxx/files/
- Application.temporaryCachePath /data/data/com.xxx.xxx/cache/
* sdcard 사용시.
- Application.persistentDataPath /mnt/sdcard/Android/data/com.xxx.xxx/files/
- Application.temporaryCachePath /mnt/sdcard/Android/data/com.xxx.xxx/cache/
'Dev > Unity3D' 카테고리의 다른 글
GameObject active 여부와 Coroutine / Invoke... (1) | 2012.06.05 |
---|---|
Unity, Audio, and Memory (0) | 2012.01.25 |
Unity3D Mesh Create Code (0) | 2011.10.20 |
Unity3D Inspector object 선택후 일괄 처리 (0) | 2011.07.02 |
Unity3D 에서 XML Serialize Encrypt/Decrypt. (3) | 2011.04.22 |
public static Mesh CreatePlaneMesh(string name, int widthSegments, int heightSegments, int width, int height, bool vertical) { int width_segments = Mathf.Clamp(widthSegments, 1, 254); int height_segments = Mathf.Clamp(heightSegments, 1, 254); Mesh m = new Mesh(); m.name = name; int hCount2 = width_segments + 1; int vCount2 = height_segments + 1; int numTriangles = width_segments * height_segments * 6; int numVertices = hCount2 * vCount2; Vector3[] vertices = new Vector3[numVertices]; Vector2[] uvs = new Vector2[numVertices]; Color[] colors = new Color[numVertices]; int[] triangles = new int[numTriangles]; int index = 0; float uvFactorX = 1.0f / width_segments; float uvFactorY = 1.0f / height_segments; float scaleX = width / width_segments; float scaleY = height / height_segments; float halfWidth = width / 2.0f; float halfHeight = height / 2.0f; float realX = -halfWidth; float realY = -halfHeight; for (float y = 0.0f; y < vCount2; y++) { for (float x = 0.0f; x < hCount2; x++) { if (vertical) { vertices[index] = new Vector3(x * scaleX + realX, y * scaleY + realY, 0.0f); } else { vertices[index] = new Vector3(x * scaleX + realX, 0.0f, y * scaleY + realY); } uvs[index++] = new Vector2(x * uvFactorX, y * uvFactorY); } } index = 0; for (int y = 0; y < height_segments; y++) { for (int x = 0; x < width_segments; x++) { triangles[index] = (y * hCount2) + x; triangles[index + 1] = ((y + 1) * hCount2) + x; triangles[index + 2] = (y * hCount2) + x + 1; triangles[index + 3] = ((y + 1) * hCount2) + x; triangles[index + 4] = ((y + 1) * hCount2) + x + 1; triangles[index + 5] = (y * hCount2) + x + 1; index += 6; } } m.vertices = vertices; m.uv = uvs; m.colors = colors; m.triangles = triangles; m.RecalculateNormals(); return m; }
'Dev > Unity3D' 카테고리의 다른 글
Unity, Audio, and Memory (0) | 2012.01.25 |
---|---|
unity3d data path! (0) | 2011.12.14 |
Unity3D Inspector object 선택후 일괄 처리 (0) | 2011.07.02 |
Unity3D 에서 XML Serialize Encrypt/Decrypt. (3) | 2011.04.22 |
FindObjectOfType fail. (0) | 2010.12.14 |
응용하면 다른 타입도 가능합니다.
아래 코드는 Assets/Editor/CusomMenu.cs 에 생성하셔야 합니다.
using UnityEditor; using UnityEngine; using System.Collections; public class CustomMenu : ScriptableObject { // ---------------------------------------------------------------------------- [MenuItem ("CustomMenu/Texture Format")] static void ChangeTexture() { SeletedChangeTexture(); } static void SeletedChangeTexture() { Object[] textures = GetSelectedTextures(); Selection.objects = new Object[0]; int count = 0; foreach(Texture2D texture in textures) { count++; string path = AssetDatabase.GetAssetPath(texture); TextureImporter textureImporter = AssetImporter.GetAtPath(path) as TextureImporter; //texture.wrapMode = TextureWrapMode.Clamp; textureImporter.textureType = TextureImporterType.Advanced; textureImporter.mipmapEnabled = false; textureImporter.npotScale = TextureImporterNPOTScale.None; textureImporter.maxTextureSize = 4096; textureImporter.textureFormat = TextureImporterFormat.AutomaticTruecolor; AssetDatabase.ImportAsset(path); Debug.Log(string.Format("[{0}/{1}] ChangeTexture progress : {2}", count, textures.Length, path)); } } static Object[] GetSelectedTextures() { return Selection.GetFiltered(typeof(Texture2D), SelectionMode.DeepAssets); } }
'Dev > Unity3D' 카테고리의 다른 글
unity3d data path! (0) | 2011.12.14 |
---|---|
Unity3D Mesh Create Code (0) | 2011.10.20 |
Unity3D 에서 XML Serialize Encrypt/Decrypt. (3) | 2011.04.22 |
FindObjectOfType fail. (0) | 2010.12.14 |
Unity Script 와 Obejct-C 연동. (0) | 2010.11.09 |
//-----------------------------------------------------------------------------
public static void SerializeEncryptObject(string path, object obj, System.Type type, SymmetricAlgorithm key)
{
using(FileStream fs = File.Open(path, FileMode.Create, FileAccess.Write, FileShare.None))
{
using(CryptoStream cs = new CryptoStream(fs, key.CreateEncryptor(), CryptoStreamMode.Write))
{
using(StreamWriter sw = new StreamWriter(cs, Encoding.UTF8))
{
try
{
XmlSerializerNamespaces ns = new XmlSerializerNamespaces();
ns.Add("", "");
XmlSerializer serializer = new XmlSerializer(type);
serializer.Serialize(sw, obj, ns);
}
catch (System.Exception ex)
{
Debug.LogWarning(ex.ToString());
}
finally
{
sw.Close();
cs.Close();
fs.Close();
}
}
}
}
}
2. Decrypt
//-----------------------------------------------------------------------------
public static string LoadXmlFromEncryptFile(string _filePath, SymmetricAlgorithm key)
{
if (File.Exists(_filePath) == false)
{
_deserializeErrorString = System.String.Format("File({0}) does not exists", _filePath);
return "";
}
using(FileStream fs = File.Open(_filePath, FileMode.Open))
{
using(CryptoStream cs = new CryptoStream(fs, key.CreateDecryptor(), CryptoStreamMode.Read))
{
using(StreamReader sr = new StreamReader(cs, Encoding.UTF8))
{
try
{
return sr.ReadToEnd();
}
catch(System.Exception ex)
{
Debug.LogWarning(ex.ToString());
_deserializeErrorString = ex.ToString();
}
finally
{
sr.Close();
cs.Close();
fs.Close();
}
}
}
}
return "";
}
3. Usage
-
private readonly string SECRET_KEY = "12345678"; // must be 64bit, 8bytes
-
private System.Security.Cryptography.DESCryptoServiceProvider mCryptoProvider = null;
-
mCryptoProvider = new System.Security.Cryptography.DESCryptoServiceProvider();
mCryptoProvider.Key = System.Text.ASCIIEncoding.ASCII.GetBytes(SECRET_KEY); mCryptoProvider.IV = System.Text.ASCIIEncoding.ASCII.GetBytes(SECRET_KEY);
-
SerializeEncryptObject("FilePath", Type, mCryptoProvider);
string xmlString = LoadXmlFromEncryptFile("FilePath", mCryptoProvider);
'Dev > Unity3D' 카테고리의 다른 글
Unity3D Mesh Create Code (0) | 2011.10.20 |
---|---|
Unity3D Inspector object 선택후 일괄 처리 (0) | 2011.07.02 |
FindObjectOfType fail. (0) | 2010.12.14 |
Unity Script 와 Obejct-C 연동. (0) | 2010.11.09 |
Unity3D 3.0 과 OpenFeint 2.7.4 연동 (4) | 2010.11.02 |