mirror of
				https://github.com/oxen-io/session-android.git
				synced 2025-10-25 09:08:37 +00:00 
			
		
		
		
	Simplify excessively convoluted camera logic
1) QuickCamera logic moved into CameraView 2) The strategies for texture vs. surface view were too complex with no observed gain. Better to remove and have to re-add if necessary than assume it to be necessary. 3) Drop CWAC-Camera dependency - the device profiles weren't being used very much and even that is deprecated so we'd be left on our own with new hardware. Not worth it. 4) Selfies first. 5) Layout/orientation mathy logic from CWAC moved into CameraUtils, with the hopes that most of it might be further simplified or rendered unnecessary in the future. Closes #4326 // FREEBIE
This commit is contained in:
		 Jake McGinty
					Jake McGinty
				
			
				
					committed by
					
						 Moxie Marlinspike
						Moxie Marlinspike
					
				
			
			
				
	
			
			
			 Moxie Marlinspike
						Moxie Marlinspike
					
				
			
						parent
						
							08be47c03e
						
					
				
				
					commit
					8fd0ea39aa
				
			| @@ -55,6 +55,7 @@ import java.util.Collection; | ||||
| import java.util.Collections; | ||||
| import java.util.LinkedList; | ||||
| import java.util.List; | ||||
| import java.util.concurrent.CountDownLatch; | ||||
| import java.util.concurrent.ExecutorService; | ||||
| import java.util.concurrent.ThreadPoolExecutor; | ||||
| import java.util.concurrent.TimeUnit; | ||||
| @@ -330,11 +331,33 @@ public class Util { | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   public static void runOnMain(Runnable runnable) { | ||||
|   public static void runOnMain(final @NonNull Runnable runnable) { | ||||
|     if (isMainThread()) runnable.run(); | ||||
|     else                handler.post(runnable); | ||||
|   } | ||||
|  | ||||
|   public static void runOnMainSync(final @NonNull Runnable runnable) { | ||||
|     if (isMainThread()) { | ||||
|       runnable.run(); | ||||
|     } else { | ||||
|       final CountDownLatch sync = new CountDownLatch(1); | ||||
|       runOnMain(new Runnable() { | ||||
|         @Override public void run() { | ||||
|           try { | ||||
|             runnable.run(); | ||||
|           } finally { | ||||
|             sync.countDown(); | ||||
|           } | ||||
|         } | ||||
|       }); | ||||
|       try { | ||||
|         sync.await(); | ||||
|       } catch (InterruptedException ie) { | ||||
|         throw new AssertionError(ie); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   public static boolean equals(@Nullable Object a, @Nullable Object b) { | ||||
|     return a == b || (a != null && a.equals(b)); | ||||
|   } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user