mirror of
https://github.com/DrKLO/Telegram.git
synced 2025-01-03 09:49:15 +01:00
update to 8.8.4
This commit is contained in:
parent
4a95c2fc1f
commit
0a3abc5158
34 changed files with 582 additions and 235 deletions
|
@ -235,7 +235,7 @@ android {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
defaultConfig.versionCode = 2705
|
defaultConfig.versionCode = 2711
|
||||||
|
|
||||||
applicationVariants.all { variant ->
|
applicationVariants.all { variant ->
|
||||||
variant.outputs.all { output ->
|
variant.outputs.all { output ->
|
||||||
|
@ -254,7 +254,7 @@ android {
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
minSdkVersion 16
|
minSdkVersion 16
|
||||||
targetSdkVersion 30
|
targetSdkVersion 30
|
||||||
versionName "8.8.3"
|
versionName "8.8.4"
|
||||||
|
|
||||||
vectorDrawables.generatedDensities = ['mdpi', 'hdpi', 'xhdpi', 'xxhdpi']
|
vectorDrawables.generatedDensities = ['mdpi', 'hdpi', 'xhdpi', 'xxhdpi']
|
||||||
|
|
||||||
|
|
|
@ -36,6 +36,7 @@ static Shape cloud_extra_mask1;
|
||||||
static Shape cloud_extra_mask2;
|
static Shape cloud_extra_mask2;
|
||||||
static Shape cloud_extra_mask3;
|
static Shape cloud_extra_mask3;
|
||||||
static Shape cloud_extra_mask4;
|
static Shape cloud_extra_mask4;
|
||||||
|
static int surfaceCreated = 0;
|
||||||
|
|
||||||
static Shape cloud_cover;
|
static Shape cloud_cover;
|
||||||
|
|
||||||
|
@ -1706,6 +1707,11 @@ JNIEXPORT void Java_org_telegram_messenger_Intro_setBackgroundColor(JNIEnv *env,
|
||||||
}
|
}
|
||||||
|
|
||||||
JNIEXPORT void Java_org_telegram_messenger_Intro_onDrawFrame(JNIEnv *env, jclass class, jint deltaMs) {
|
JNIEXPORT void Java_org_telegram_messenger_Intro_onDrawFrame(JNIEnv *env, jclass class, jint deltaMs) {
|
||||||
|
if (surfaceCreated == 0) {
|
||||||
|
glClearColor(background_color[0], background_color[1], background_color[2], background_color[3]);
|
||||||
|
glClear(GL_COLOR_BUFFER_BIT);
|
||||||
|
return;
|
||||||
|
}
|
||||||
time_local += (float) deltaMs / 1000;
|
time_local += (float) deltaMs / 1000;
|
||||||
|
|
||||||
if (current_page != prev_page) {
|
if (current_page != prev_page) {
|
||||||
|
@ -2826,6 +2832,7 @@ JNIEXPORT void Java_org_telegram_messenger_Intro_onSurfaceCreated(JNIEnv *env, j
|
||||||
|
|
||||||
vec4 cloud_color = {42 / 255.0f, 180 / 255.0f, 247 / 255.0f, 1};
|
vec4 cloud_color = {42 / 255.0f, 180 / 255.0f, 247 / 255.0f, 1};
|
||||||
cloud_bg = create_rectangle(CSizeMake(160 * 2, 160 * 2), cloud_color);
|
cloud_bg = create_rectangle(CSizeMake(160 * 2, 160 * 2), cloud_color);
|
||||||
|
surfaceCreated = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
JNIEXPORT void Java_org_telegram_messenger_Intro_onSurfaceChanged(JNIEnv *env, jclass class, int32_t a_width_px, int32_t a_height_px, float a_scale_factor, int32_t a1) {
|
JNIEXPORT void Java_org_telegram_messenger_Intro_onSurfaceChanged(JNIEnv *env, jclass class, int32_t a_width_px, int32_t a_height_px, float a_scale_factor, int32_t a1) {
|
||||||
|
|
|
@ -28,14 +28,15 @@ uniform vec4 gradientPosition;
|
||||||
void main() {
|
void main() {
|
||||||
vec3 vLightPosition2 = vec3(-400,400,400);
|
vec3 vLightPosition2 = vec3(-400,400,400);
|
||||||
vec3 vLightPosition3 = vec3(0,200,400);
|
vec3 vLightPosition3 = vec3(0,200,400);
|
||||||
vec3 vLightPosition4 = vec3(100,-200,400);
|
vec3 vLightPosition4 = vec3(0,0,100);
|
||||||
|
vec3 vLightPositionNormal = vec3(100,-200,400);
|
||||||
|
|
||||||
vec3 vNormalW = normalize(vec3(world * vec4(vNormal, 0.0)));
|
vec3 vNormalW = normalize(vec3(world * vec4(vNormal, 0.0)));
|
||||||
vec3 vTextureNormal = normalize(texture2D(u_NormalMap, vUV + vec2(-f_xOffset, f_xOffset)).xyz * 2.0 - 1.0);
|
vec3 vTextureNormal = normalize(texture2D(u_NormalMap, vUV + vec2(-f_xOffset, f_xOffset)).xyz * 2.0 - 1.0);
|
||||||
|
|
||||||
vec3 finalNormal = normalize(vNormalW + vTextureNormal);
|
vec3 finalNormal = normalize(vNormalW + vTextureNormal);
|
||||||
|
|
||||||
vec3 color = texture2D(u_Texture, vUV * vec2(0.8, 0.8) + vec2(0.2 * f_xOffset, 0)).xyz;
|
vec3 color = texture2D(u_Texture, vUV ).xyz;
|
||||||
vec3 viewDirectionW = normalize(cameraPosition - modelViewVertex);
|
vec3 viewDirectionW = normalize(cameraPosition - modelViewVertex);
|
||||||
|
|
||||||
vec3 angleW = normalize(viewDirectionW + vLightPosition2);
|
vec3 angleW = normalize(viewDirectionW + vLightPosition2);
|
||||||
|
@ -44,14 +45,14 @@ void main() {
|
||||||
|
|
||||||
angleW = normalize(viewDirectionW + vLightPosition4);
|
angleW = normalize(viewDirectionW + vLightPosition4);
|
||||||
float specComp3 = max(0., dot(vNormalW, angleW));
|
float specComp3 = max(0., dot(vNormalW, angleW));
|
||||||
specComp3 = pow(specComp3, max(1., 128.)) * spec2;
|
specComp3 = pow(specComp3, max(1., 30.)) * spec2;
|
||||||
|
|
||||||
float diffuse = max(dot(vNormalW, viewDirectionW), (1.0 - u_diffuse));
|
float diffuse = max(dot(vNormalW, viewDirectionW), (1.0 - u_diffuse));
|
||||||
|
|
||||||
float mixValue = distance(vUV,vec2(1,0));
|
float mixValue = distance(vUV,vec2(1,0));
|
||||||
vec4 gradientColorFinal = vec4(mix(gradientColor1,gradientColor2,mixValue), 1.0);
|
vec4 gradientColorFinal = vec4(mix(gradientColor1,gradientColor2,mixValue), 1.0);
|
||||||
|
|
||||||
angleW = normalize(viewDirectionW + vLightPosition4);
|
angleW = normalize(viewDirectionW + vLightPositionNormal);
|
||||||
float normalSpecComp = max(0., dot(finalNormal, angleW));
|
float normalSpecComp = max(0., dot(finalNormal, angleW));
|
||||||
normalSpecComp = pow(normalSpecComp, max(1., 128.)) * normalSpec;
|
normalSpecComp = pow(normalSpecComp, max(1., 128.)) * normalSpec;
|
||||||
|
|
||||||
|
@ -60,7 +61,7 @@ void main() {
|
||||||
normalSpecComp2 = pow(normalSpecComp2, max(1., 128.)) * normalSpec;
|
normalSpecComp2 = pow(normalSpecComp2, max(1., 128.)) * normalSpec;
|
||||||
|
|
||||||
vec4 normalSpecFinal = vec4(normalSpecColor, 0.0) * (normalSpecComp + normalSpecComp2);
|
vec4 normalSpecFinal = vec4(normalSpecColor, 0.0) * (normalSpecComp + normalSpecComp2);
|
||||||
vec4 specFinal = vec4(specColor, 0.0) * (specComp2 + specComp3);
|
vec4 specFinal = vec4(color, 0.0) * (specComp2 + specComp3);
|
||||||
|
|
||||||
vec4 fragColor = gradientColorFinal + specFinal + normalSpecFinal;
|
vec4 fragColor = gradientColorFinal + specFinal + normalSpecFinal;
|
||||||
vec4 backgroundColor = texture2D(u_BackgroundTexture, vec2(gradientPosition.x + (gl_FragCoord.x / resolution.x) * gradientPosition.y, gradientPosition.z + (1.0 - (gl_FragCoord.y / resolution.y)) * gradientPosition.w));
|
vec4 backgroundColor = texture2D(u_BackgroundTexture, vec2(gradientPosition.x + (gl_FragCoord.x / resolution.x) * gradientPosition.y, gradientPosition.z + (1.0 - (gl_FragCoord.y / resolution.y)) * gradientPosition.w));
|
||||||
|
|
|
@ -20,10 +20,10 @@ public class BuildVars {
|
||||||
public static boolean USE_CLOUD_STRINGS = true;
|
public static boolean USE_CLOUD_STRINGS = true;
|
||||||
public static boolean CHECK_UPDATES = true;
|
public static boolean CHECK_UPDATES = true;
|
||||||
public static boolean NO_SCOPED_STORAGE = Build.VERSION.SDK_INT <= 29;
|
public static boolean NO_SCOPED_STORAGE = Build.VERSION.SDK_INT <= 29;
|
||||||
public static int BUILD_VERSION = 2705;
|
public static int BUILD_VERSION = 2711;
|
||||||
public static String BUILD_VERSION_STRING = "8.8.3";
|
public static String BUILD_VERSION_STRING = "8.8.4";
|
||||||
public static int APP_ID = 4;
|
public static int APP_ID = 4;
|
||||||
public static String APP_HASH = "014b35b6184100b085b0d0572f9b5103";
|
public static String APP_HASH = "014b35b6184100b085b0d0572f9b5103";;
|
||||||
|
|
||||||
public static String SMS_HASH = isStandaloneApp() ? "w0lkcmTZkKh" : (DEBUG_VERSION ? "O2P2z+/jBpJ" : "oLeq9AcOZkT");
|
public static String SMS_HASH = isStandaloneApp() ? "w0lkcmTZkKh" : (DEBUG_VERSION ? "O2P2z+/jBpJ" : "oLeq9AcOZkT");
|
||||||
public static String PLAYSTORE_APP_URL = "https://play.google.com/store/apps/details?id=org.telegram.messenger";
|
public static String PLAYSTORE_APP_URL = "https://play.google.com/store/apps/details?id=org.telegram.messenger";
|
||||||
|
|
|
@ -46,6 +46,8 @@ public class FileLoadOperation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static final Object lockObject = new Object();
|
||||||
|
|
||||||
private static class PreloadRange {
|
private static class PreloadRange {
|
||||||
private long fileOffset;
|
private long fileOffset;
|
||||||
private long length;
|
private long length;
|
||||||
|
@ -182,7 +184,7 @@ public class FileLoadOperation {
|
||||||
|
|
||||||
private void updateParams() {
|
private void updateParams() {
|
||||||
if (MessagesController.getInstance(currentAccount).getfileExperimentalParams) {
|
if (MessagesController.getInstance(currentAccount).getfileExperimentalParams) {
|
||||||
downloadChunkSizeBig = 1024 * 512;
|
downloadChunkSizeBig = 1024 * 128;
|
||||||
maxDownloadRequests = 8;
|
maxDownloadRequests = 8;
|
||||||
maxDownloadRequestsBig = 8;
|
maxDownloadRequestsBig = 8;
|
||||||
} else {
|
} else {
|
||||||
|
@ -770,7 +772,11 @@ public class FileLoadOperation {
|
||||||
TLRPC.TL_theme theme = (TLRPC.TL_theme) parentObject;
|
TLRPC.TL_theme theme = (TLRPC.TL_theme) parentObject;
|
||||||
cacheFileFinal = new File(ApplicationLoader.getFilesDirFixed(), "remote" + theme.id + ".attheme");
|
cacheFileFinal = new File(ApplicationLoader.getFilesDirFixed(), "remote" + theme.id + ".attheme");
|
||||||
} else {
|
} else {
|
||||||
cacheFileFinal = new File(storePath, storeFileName);
|
if (!encryptFile) {
|
||||||
|
cacheFileFinal = new File(storePath, storeFileName);
|
||||||
|
} else {
|
||||||
|
cacheFileFinal = new File(storePath, fileNameFinal);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
boolean finalFileExist = cacheFileFinal.exists();
|
boolean finalFileExist = cacheFileFinal.exists();
|
||||||
if (finalFileExist && (parentObject instanceof TLRPC.TL_theme || totalBytesCount != 0 && totalBytesCount != cacheFileFinal.length())) {
|
if (finalFileExist && (parentObject instanceof TLRPC.TL_theme || totalBytesCount != 0 && totalBytesCount != cacheFileFinal.length())) {
|
||||||
|
@ -1253,18 +1259,20 @@ public class FileLoadOperation {
|
||||||
} else {
|
} else {
|
||||||
try {
|
try {
|
||||||
if (pathSaveData != null) {
|
if (pathSaveData != null) {
|
||||||
cacheFileFinal = new File(storePath, storeFileName);
|
synchronized (lockObject) {
|
||||||
int count = 1;
|
cacheFileFinal = new File(storePath, storeFileName);
|
||||||
while (cacheFileFinal.exists()) {
|
int count = 1;
|
||||||
int lastDotIndex = storeFileName.lastIndexOf('.');
|
while (cacheFileFinal.exists()) {
|
||||||
String newFileName;
|
int lastDotIndex = storeFileName.lastIndexOf('.');
|
||||||
if (lastDotIndex > 0) {
|
String newFileName;
|
||||||
newFileName = storeFileName.substring(0, lastDotIndex) + " (" + count + ")" + storeFileName.substring(lastDotIndex);
|
if (lastDotIndex > 0) {
|
||||||
} else {
|
newFileName = storeFileName.substring(0, lastDotIndex) + " (" + count + ")" + storeFileName.substring(lastDotIndex);
|
||||||
newFileName = storeFileName + " (" + count + ")";
|
} else {
|
||||||
|
newFileName = storeFileName + " (" + count + ")";
|
||||||
|
}
|
||||||
|
cacheFileFinal = new File(storePath, newFileName);
|
||||||
|
count++;
|
||||||
}
|
}
|
||||||
cacheFileFinal = new File(storePath, newFileName);
|
|
||||||
count++;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
renameResult = cacheFileTemp.renameTo(cacheFileFinal);
|
renameResult = cacheFileTemp.renameTo(cacheFileFinal);
|
||||||
|
@ -1290,14 +1298,15 @@ public class FileLoadOperation {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
cacheFileFinal = cacheFileTemp;
|
cacheFileFinal = cacheFileTemp;
|
||||||
|
} else {
|
||||||
|
if (pathSaveData != null && cacheFileFinal.exists()) {
|
||||||
|
delegate.saveFilePath(pathSaveData, cacheFileFinal);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
onFail(false, 0);
|
onFail(false, 0);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (pathSaveData != null && cacheFileFinal.exists()) {
|
|
||||||
delegate.saveFilePath(pathSaveData, cacheFileFinal);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (BuildVars.LOGS_ENABLED) {
|
if (BuildVars.LOGS_ENABLED) {
|
||||||
FileLog.d("finished downloading file to " + cacheFileFinal);
|
FileLog.d("finished downloading file to " + cacheFileFinal);
|
||||||
|
|
|
@ -629,6 +629,9 @@ public class FileLoader extends BaseController {
|
||||||
}
|
}
|
||||||
|
|
||||||
FileLoadOperation operation = loadOperationPaths.get(fileName);
|
FileLoadOperation operation = loadOperationPaths.get(fileName);
|
||||||
|
if (BuildVars.LOGS_ENABLED) {
|
||||||
|
FileLog.d("checkFile operation fileName=" + fileName + " documentName=" + getDocumentFileName(document) + " operation=" + operation);
|
||||||
|
}
|
||||||
if (operation != null) {
|
if (operation != null) {
|
||||||
if (cacheType != 10 && operation.isPreloadVideoOperation()) {
|
if (cacheType != 10 && operation.isPreloadVideoOperation()) {
|
||||||
operation.setIsPreloadVideoOperation(false);
|
operation.setIsPreloadVideoOperation(false);
|
||||||
|
@ -675,7 +678,6 @@ public class FileLoader extends BaseController {
|
||||||
int type = MEDIA_DIR_CACHE;
|
int type = MEDIA_DIR_CACHE;
|
||||||
long documentId = 0;
|
long documentId = 0;
|
||||||
int dcId = 0;
|
int dcId = 0;
|
||||||
String lastKnownPath = null;
|
|
||||||
|
|
||||||
if (secureDocument != null) {
|
if (secureDocument != null) {
|
||||||
operation = new FileLoadOperation(secureDocument);
|
operation = new FileLoadOperation(secureDocument);
|
||||||
|
@ -687,14 +689,20 @@ public class FileLoader extends BaseController {
|
||||||
type = MEDIA_DIR_IMAGE;
|
type = MEDIA_DIR_IMAGE;
|
||||||
} else if (document != null) {
|
} else if (document != null) {
|
||||||
operation = new FileLoadOperation(document, parentObject);
|
operation = new FileLoadOperation(document, parentObject);
|
||||||
documentId = document.id;
|
|
||||||
dcId = document.dc_id;
|
|
||||||
if (MessageObject.isVoiceDocument(document)) {
|
if (MessageObject.isVoiceDocument(document)) {
|
||||||
type = MEDIA_DIR_AUDIO;
|
type = MEDIA_DIR_AUDIO;
|
||||||
} else if (MessageObject.isVideoDocument(document)) {
|
} else if (MessageObject.isVideoDocument(document)) {
|
||||||
type = MEDIA_DIR_VIDEO;
|
type = MEDIA_DIR_VIDEO;
|
||||||
|
documentId = document.id;
|
||||||
|
dcId = document.dc_id;
|
||||||
} else {
|
} else {
|
||||||
type = MEDIA_DIR_DOCUMENT;
|
type = MEDIA_DIR_DOCUMENT;
|
||||||
|
documentId = document.id;
|
||||||
|
dcId = document.dc_id;
|
||||||
|
}
|
||||||
|
if (MessageObject.isRoundVideoDocument(document)) {
|
||||||
|
documentId = 0;
|
||||||
|
dcId = 0;
|
||||||
}
|
}
|
||||||
} else if (webDocument != null) {
|
} else if (webDocument != null) {
|
||||||
operation = new FileLoadOperation(currentAccount, webDocument);
|
operation = new FileLoadOperation(currentAccount, webDocument);
|
||||||
|
@ -831,33 +839,34 @@ public class FileLoader extends BaseController {
|
||||||
operation.setPriority(priority);
|
operation.setPriority(priority);
|
||||||
|
|
||||||
boolean started;
|
boolean started;
|
||||||
|
int maxCount, count;
|
||||||
if (queueType == QUEUE_TYPE_PRELOAD) {
|
if (queueType == QUEUE_TYPE_PRELOAD) {
|
||||||
int maxCount = priority > 0 ? 6 : 2;
|
maxCount = priority > 0 ? 6 : 2;
|
||||||
int count = preloadingLoadOperationsCount.get(datacenterId);
|
count = preloadingLoadOperationsCount.get(datacenterId);
|
||||||
if (started = (stream != null || count < maxCount)) {
|
if (started = (stream != null || count < maxCount)) {
|
||||||
if (operation.start(stream, streamOffset, streamPriority)) {
|
if (operation.start(stream, streamOffset, streamPriority)) {
|
||||||
preloadingLoadOperationsCount.put(datacenterId, count + 1);
|
preloadingLoadOperationsCount.put(datacenterId, count + 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (queueType == QUEUE_TYPE_AUDIO) {
|
} else if (queueType == QUEUE_TYPE_AUDIO) {
|
||||||
int maxCount = priority > 0 ? 3 : 1;
|
maxCount = priority > 0 ? 3 : 1;
|
||||||
int count = audioLoadOperationsCount.get(datacenterId);
|
count = audioLoadOperationsCount.get(datacenterId);
|
||||||
if (started = (stream != null || count < maxCount)) {
|
if (started = (stream != null || count < maxCount)) {
|
||||||
if (operation.start(stream, streamOffset, streamPriority)) {
|
if (operation.start(stream, streamOffset, streamPriority)) {
|
||||||
audioLoadOperationsCount.put(datacenterId, count + 1);
|
audioLoadOperationsCount.put(datacenterId, count + 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (queueType == QUEUE_TYPE_IMAGE) {
|
} else if (queueType == QUEUE_TYPE_IMAGE) {
|
||||||
int maxCount = priority > 0 ? 6 : 2;
|
maxCount = priority > 0 ? 6 : 2;
|
||||||
int count = imageLoadOperationsCount.get(datacenterId);
|
count = imageLoadOperationsCount.get(datacenterId);
|
||||||
if (started = (stream != null || count < maxCount)) {
|
if (started = (stream != null || count < maxCount)) {
|
||||||
if (operation.start(stream, streamOffset, streamPriority)) {
|
if (operation.start(stream, streamOffset, streamPriority)) {
|
||||||
imageLoadOperationsCount.put(datacenterId, count + 1);
|
imageLoadOperationsCount.put(datacenterId, count + 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
int maxCount = priority > 0 ? 4 : 1;
|
maxCount = priority > 0 ? 4 : 1;
|
||||||
int count = fileLoadOperationsCount.get(datacenterId);
|
count = fileLoadOperationsCount.get(datacenterId);
|
||||||
if (started = (stream != null || count < maxCount)) {
|
if (started = (stream != null || count < maxCount)) {
|
||||||
if (operation.start(stream, streamOffset, streamPriority)) {
|
if (operation.start(stream, streamOffset, streamPriority)) {
|
||||||
fileLoadOperationsCount.put(datacenterId, count + 1);
|
fileLoadOperationsCount.put(datacenterId, count + 1);
|
||||||
|
@ -868,6 +877,11 @@ public class FileLoader extends BaseController {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (BuildVars.LOGS_ENABLED) {
|
||||||
|
FileLog.d("loadFileInternal fileName=" + fileName + " documentName=" + getDocumentFileName(document) + " queueType=" + queueType + " maxCount=" + maxCount + " count=" + count);
|
||||||
|
}
|
||||||
|
|
||||||
if (!started) {
|
if (!started) {
|
||||||
addOperationToQueue(operation, getLoadOperationQueue(datacenterId, queueType));
|
addOperationToQueue(operation, getLoadOperationQueue(datacenterId, queueType));
|
||||||
}
|
}
|
||||||
|
@ -893,7 +907,7 @@ public class FileLoader extends BaseController {
|
||||||
MessageObject messageObject = (MessageObject) parentObject;
|
MessageObject messageObject = (MessageObject) parentObject;
|
||||||
int flag;
|
int flag;
|
||||||
long dialogId = messageObject.getDialogId();
|
long dialogId = messageObject.getDialogId();
|
||||||
if (messageObject.isAnyKindOfSticker() || getMessagesController().isChatNoForwards(getMessagesController().getChat(-dialogId)) || messageObject.messageOwner.noforwards) {
|
if (messageObject.isRoundVideo() || messageObject.isVoice() || messageObject.isAnyKindOfSticker() || getMessagesController().isChatNoForwards(getMessagesController().getChat(-dialogId)) || messageObject.messageOwner.noforwards) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (dialogId >= 0) {
|
if (dialogId >= 0) {
|
||||||
|
@ -1162,17 +1176,22 @@ public class FileLoader extends BaseController {
|
||||||
if (photoSize instanceof TLRPC.TL_photoStrippedSize || photoSize instanceof TLRPC.TL_photoPathSize) {
|
if (photoSize instanceof TLRPC.TL_photoStrippedSize || photoSize instanceof TLRPC.TL_photoPathSize) {
|
||||||
dir = null;
|
dir = null;
|
||||||
} else if (photoSize.location == null || photoSize.location.key != null || photoSize.location.volume_id == Integer.MIN_VALUE && photoSize.location.local_id < 0 || photoSize.size < 0) {
|
} else if (photoSize.location == null || photoSize.location.key != null || photoSize.location.volume_id == Integer.MIN_VALUE && photoSize.location.local_id < 0 || photoSize.size < 0) {
|
||||||
dir = getDirectory(MEDIA_DIR_CACHE);
|
dir = getDirectory(type = MEDIA_DIR_CACHE);
|
||||||
} else {
|
} else {
|
||||||
dir = getDirectory(MEDIA_DIR_IMAGE);
|
dir = getDirectory(type = MEDIA_DIR_IMAGE);
|
||||||
}
|
}
|
||||||
|
documentId = photoSize.location.volume_id;
|
||||||
|
dcId = photoSize.location.dc_id;
|
||||||
|
|
||||||
} else if (attach instanceof TLRPC.TL_videoSize) {
|
} else if (attach instanceof TLRPC.TL_videoSize) {
|
||||||
TLRPC.TL_videoSize videoSize = (TLRPC.TL_videoSize) attach;
|
TLRPC.TL_videoSize videoSize = (TLRPC.TL_videoSize) attach;
|
||||||
if (videoSize.location == null || videoSize.location.key != null || videoSize.location.volume_id == Integer.MIN_VALUE && videoSize.location.local_id < 0 || videoSize.size < 0) {
|
if (videoSize.location == null || videoSize.location.key != null || videoSize.location.volume_id == Integer.MIN_VALUE && videoSize.location.local_id < 0 || videoSize.size < 0) {
|
||||||
dir = getDirectory(MEDIA_DIR_CACHE);
|
dir = getDirectory(type = MEDIA_DIR_CACHE);
|
||||||
} else {
|
} else {
|
||||||
dir = getDirectory(MEDIA_DIR_IMAGE);
|
dir = getDirectory(type = MEDIA_DIR_IMAGE);
|
||||||
}
|
}
|
||||||
|
documentId = videoSize.location.volume_id;
|
||||||
|
dcId = videoSize.location.dc_id;
|
||||||
} else if (attach instanceof TLRPC.FileLocation) {
|
} else if (attach instanceof TLRPC.FileLocation) {
|
||||||
TLRPC.FileLocation fileLocation = (TLRPC.FileLocation) attach;
|
TLRPC.FileLocation fileLocation = (TLRPC.FileLocation) attach;
|
||||||
if (fileLocation.key != null || fileLocation.volume_id == Integer.MIN_VALUE && fileLocation.local_id < 0) {
|
if (fileLocation.key != null || fileLocation.volume_id == Integer.MIN_VALUE && fileLocation.local_id < 0) {
|
||||||
|
@ -1614,6 +1633,10 @@ public class FileLoader extends BaseController {
|
||||||
getDownloadController().clearRecentDownloadedFiles();
|
getDownloadController().clearRecentDownloadedFiles();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void clearFilePaths() {
|
||||||
|
filePathDatabase.clear();
|
||||||
|
}
|
||||||
|
|
||||||
public static boolean checkUploadFileSize(int currentAccount, long length) {
|
public static boolean checkUploadFileSize(int currentAccount, long length) {
|
||||||
boolean premium = AccountInstance.getInstance(currentAccount).getUserConfig().isPremium();
|
boolean premium = AccountInstance.getInstance(currentAccount).getUserConfig().isPremium();
|
||||||
if (length < DEFAULT_MAX_FILE_SIZE || (length < DEFAULT_MAX_FILE_SIZE_PREMIUM && premium)) {
|
if (length < DEFAULT_MAX_FILE_SIZE || (length < DEFAULT_MAX_FILE_SIZE_PREMIUM && premium)) {
|
||||||
|
|
|
@ -61,7 +61,7 @@ public class FilePathDatabase {
|
||||||
} else {
|
} else {
|
||||||
int version = database.executeInt("PRAGMA user_version");
|
int version = database.executeInt("PRAGMA user_version");
|
||||||
if (BuildVars.LOGS_ENABLED) {
|
if (BuildVars.LOGS_ENABLED) {
|
||||||
FileLog.d("current db version = " + version);
|
FileLog.d("current files db version = " + version);
|
||||||
}
|
}
|
||||||
if (version == 0) {
|
if (version == 0) {
|
||||||
throw new Exception("malformed");
|
throw new Exception("malformed");
|
||||||
|
@ -140,6 +140,9 @@ public class FilePathDatabase {
|
||||||
cursor = database.queryFinalized("SELECT path FROM paths WHERE document_id = " + documentId + " AND dc_id = " + dc + " AND type = " + type);
|
cursor = database.queryFinalized("SELECT path FROM paths WHERE document_id = " + documentId + " AND dc_id = " + dc + " AND type = " + type);
|
||||||
if (cursor.next()) {
|
if (cursor.next()) {
|
||||||
res[0] = cursor.stringValue(0);
|
res[0] = cursor.stringValue(0);
|
||||||
|
if (BuildVars.DEBUG_VERSION) {
|
||||||
|
FileLog.d("get file path id=" + documentId + " dc=" + dc + " type=" + type + " path=" + res[0]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
cursor.dispose();
|
cursor.dispose();
|
||||||
} catch (SQLiteException e) {
|
} catch (SQLiteException e) {
|
||||||
|
@ -159,6 +162,9 @@ public class FilePathDatabase {
|
||||||
cursor = database.queryFinalized("SELECT path FROM paths WHERE document_id = " + documentId + " AND dc_id = " + dc + " AND type = " + type);
|
cursor = database.queryFinalized("SELECT path FROM paths WHERE document_id = " + documentId + " AND dc_id = " + dc + " AND type = " + type);
|
||||||
if (cursor.next()) {
|
if (cursor.next()) {
|
||||||
res = cursor.stringValue(0);
|
res = cursor.stringValue(0);
|
||||||
|
if (BuildVars.DEBUG_VERSION) {
|
||||||
|
FileLog.d("get file path id=" + documentId + " dc=" + dc + " type=" + type + " path=" + res);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
cursor.dispose();
|
cursor.dispose();
|
||||||
} catch (SQLiteException e) {
|
} catch (SQLiteException e) {
|
||||||
|
@ -170,6 +176,9 @@ public class FilePathDatabase {
|
||||||
|
|
||||||
public void putPath(long id, int dc, int type, String path) {
|
public void putPath(long id, int dc, int type, String path) {
|
||||||
dispatchQueue.postRunnable(() -> {
|
dispatchQueue.postRunnable(() -> {
|
||||||
|
if (BuildVars.DEBUG_VERSION) {
|
||||||
|
FileLog.d("put file path id=" + id + " dc=" + dc + " type=" + type + " path=" + path);
|
||||||
|
}
|
||||||
SQLitePreparedStatement state = null;
|
SQLitePreparedStatement state = null;
|
||||||
try {
|
try {
|
||||||
if (path != null) {
|
if (path != null) {
|
||||||
|
@ -224,6 +233,16 @@ public class FilePathDatabase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void clear() {
|
||||||
|
dispatchQueue.postRunnable(() -> {
|
||||||
|
try {
|
||||||
|
database.executeFast("DELETE FROM paths WHERE 1").stepThis().dispose();
|
||||||
|
} catch (SQLiteException e) {
|
||||||
|
FileLog.e(e);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
public static class PathData {
|
public static class PathData {
|
||||||
public final long id;
|
public final long id;
|
||||||
public final int dc;
|
public final int dc;
|
||||||
|
|
|
@ -997,7 +997,7 @@ public class ImageLoader {
|
||||||
boolean needInvert = false;
|
boolean needInvert = false;
|
||||||
int orientation = 0;
|
int orientation = 0;
|
||||||
File cacheFileFinal = cacheImage.finalFilePath;
|
File cacheFileFinal = cacheImage.finalFilePath;
|
||||||
boolean inEncryptedFile = cacheImage.secureDocument != null || cacheImage.encryptionKeyPath != null && cacheFileFinal != null && (cacheFileFinal.getAbsolutePath().endsWith(".enc") || cacheFileFinal.getAbsolutePath().endsWith(".64enc"));
|
boolean inEncryptedFile = cacheImage.secureDocument != null || cacheImage.encryptionKeyPath != null && cacheFileFinal != null && cacheFileFinal.getAbsolutePath().endsWith(".enc");
|
||||||
SecureDocumentKey secureDocumentKey;
|
SecureDocumentKey secureDocumentKey;
|
||||||
byte[] secureDocumentHash;
|
byte[] secureDocumentHash;
|
||||||
if (cacheImage.secureDocument != null) {
|
if (cacheImage.secureDocument != null) {
|
||||||
|
|
|
@ -359,20 +359,21 @@ public class ImageReceiver implements NotificationCenter.NotificationCenterDeleg
|
||||||
if (user.photo != null) {
|
if (user.photo != null) {
|
||||||
strippedBitmap = user.photo.strippedBitmap;
|
strippedBitmap = user.photo.strippedBitmap;
|
||||||
hasStripped = user.photo.stripped_thumb != null;
|
hasStripped = user.photo.stripped_thumb != null;
|
||||||
if (MessagesController.getInstance(currentAccount).isPremiumUser(user) && user.photo.has_video && animationEnabled) {
|
if (animationEnabled && MessagesController.getInstance(currentAccount).isPremiumUser(user) && user.photo.has_video) {
|
||||||
final TLRPC.UserFull userFull = MessagesController.getInstance(currentAccount).getUserFull(user.id);
|
final TLRPC.UserFull userFull = MessagesController.getInstance(currentAccount).getUserFull(user.id);
|
||||||
if (userFull == null) {
|
if (userFull == null) {
|
||||||
MessagesController.getInstance(currentAccount).loadFullUser(user, currentGuid, false);
|
MessagesController.getInstance(currentAccount).loadFullUser(user, currentGuid, false);
|
||||||
}
|
} else {
|
||||||
if (userFull != null && userFull.profile_photo != null && userFull.profile_photo.video_sizes != null && !userFull.profile_photo.video_sizes.isEmpty()) {
|
if (userFull.profile_photo != null && userFull.profile_photo.video_sizes != null && !userFull.profile_photo.video_sizes.isEmpty()) {
|
||||||
TLRPC.VideoSize videoSize = userFull.profile_photo.video_sizes.get(0);
|
TLRPC.VideoSize videoSize = userFull.profile_photo.video_sizes.get(0);
|
||||||
for (int i = 0; i < userFull.profile_photo.video_sizes.size(); i++) {
|
for (int i = 0; i < userFull.profile_photo.video_sizes.size(); i++) {
|
||||||
if ("p".equals(userFull.profile_photo.video_sizes.get(i).type)) {
|
if ("p".equals(userFull.profile_photo.video_sizes.get(i).type)) {
|
||||||
videoSize = userFull.profile_photo.video_sizes.get(i);
|
videoSize = userFull.profile_photo.video_sizes.get(i);
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
videoLocation = ImageLocation.getForPhoto(videoSize, userFull.profile_photo);
|
||||||
}
|
}
|
||||||
videoLocation = ImageLocation.getForPhoto(videoSize, userFull.profile_photo);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -101,11 +101,17 @@ public class MediaDataController extends BaseController {
|
||||||
public static String SHORTCUT_CATEGORY = "org.telegram.messenger.SHORTCUT_SHARE";
|
public static String SHORTCUT_CATEGORY = "org.telegram.messenger.SHORTCUT_SHARE";
|
||||||
|
|
||||||
private static volatile MediaDataController[] Instance = new MediaDataController[UserConfig.MAX_ACCOUNT_COUNT];
|
private static volatile MediaDataController[] Instance = new MediaDataController[UserConfig.MAX_ACCOUNT_COUNT];
|
||||||
|
private static final Object[] lockObjects = new Object[UserConfig.MAX_ACCOUNT_COUNT];
|
||||||
|
static {
|
||||||
|
for (int i = 0; i < UserConfig.MAX_ACCOUNT_COUNT; i++) {
|
||||||
|
lockObjects[i] = new Object();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static MediaDataController getInstance(int num) {
|
public static MediaDataController getInstance(int num) {
|
||||||
MediaDataController localInstance = Instance[num];
|
MediaDataController localInstance = Instance[num];
|
||||||
if (localInstance == null) {
|
if (localInstance == null) {
|
||||||
synchronized (MediaDataController.class) {
|
synchronized (lockObjects) {
|
||||||
localInstance = Instance[num];
|
localInstance = Instance[num];
|
||||||
if (localInstance == null) {
|
if (localInstance == null) {
|
||||||
Instance[num] = localInstance = new MediaDataController(num);
|
Instance[num] = localInstance = new MediaDataController(num);
|
||||||
|
|
|
@ -873,7 +873,7 @@ public class MessagesController extends BaseController implements NotificationCe
|
||||||
};
|
};
|
||||||
|
|
||||||
private static volatile MessagesController[] Instance = new MessagesController[UserConfig.MAX_ACCOUNT_COUNT];
|
private static volatile MessagesController[] Instance = new MessagesController[UserConfig.MAX_ACCOUNT_COUNT];
|
||||||
private static volatile Object[] lockObjects = new Object[UserConfig.MAX_ACCOUNT_COUNT];
|
private static final Object[] lockObjects = new Object[UserConfig.MAX_ACCOUNT_COUNT];
|
||||||
static {
|
static {
|
||||||
for (int i = 0; i < UserConfig.MAX_ACCOUNT_COUNT; i++) {
|
for (int i = 0; i < UserConfig.MAX_ACCOUNT_COUNT; i++) {
|
||||||
lockObjects[i] = new Object();
|
lockObjects[i] = new Object();
|
||||||
|
@ -1624,6 +1624,7 @@ public class MessagesController extends BaseController implements NotificationCe
|
||||||
SharedPreferences.Editor editor = mainPreferences.edit();
|
SharedPreferences.Editor editor = mainPreferences.edit();
|
||||||
boolean changed = false;
|
boolean changed = false;
|
||||||
boolean keelAliveChanged = false;
|
boolean keelAliveChanged = false;
|
||||||
|
resetAppConfig();
|
||||||
TLRPC.TL_jsonObject object = (TLRPC.TL_jsonObject) response;
|
TLRPC.TL_jsonObject object = (TLRPC.TL_jsonObject) response;
|
||||||
for (int a = 0, N = object.value.size(); a < N; a++) {
|
for (int a = 0, N = object.value.size(); a < N; a++) {
|
||||||
TLRPC.TL_jsonObjectValue value = object.value.get(a);
|
TLRPC.TL_jsonObjectValue value = object.value.get(a);
|
||||||
|
@ -2410,6 +2411,11 @@ public class MessagesController extends BaseController implements NotificationCe
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void resetAppConfig() {
|
||||||
|
getfileExperimentalParams = false;
|
||||||
|
mainPreferences.edit().remove("getfileExperimentalParams");
|
||||||
|
}
|
||||||
|
|
||||||
private boolean savePremiumFeaturesPreviewOrder(SharedPreferences.Editor editor, ArrayList<TLRPC.JSONValue> value) {
|
private boolean savePremiumFeaturesPreviewOrder(SharedPreferences.Editor editor, ArrayList<TLRPC.JSONValue> value) {
|
||||||
StringBuilder stringBuilder = new StringBuilder();
|
StringBuilder stringBuilder = new StringBuilder();
|
||||||
premiumFeaturesTypesToPosition.clear();
|
premiumFeaturesTypesToPosition.clear();
|
||||||
|
@ -9133,7 +9139,7 @@ public class MessagesController extends BaseController implements NotificationCe
|
||||||
}
|
}
|
||||||
MessageObject oldMsg = dialogMessage.get(key);
|
MessageObject oldMsg = dialogMessage.get(key);
|
||||||
if (BuildVars.LOGS_ENABLED) {
|
if (BuildVars.LOGS_ENABLED) {
|
||||||
FileLog.d("processDialogsUpdate oldMsg " + oldMsg + " old top_message = " + currentDialog.top_message + " new top_message = " + value.top_message);
|
FileLog.d("processDialogsUpdate oldMsg " + oldMsg + " old top_message = " + currentDialog.top_message + " new top_message = " + value.top_message + " unread_count =" + currentDialog.unread_count + " fromCache=" + fromCache);
|
||||||
FileLog.d("processDialogsUpdate oldMsgDeleted " + (oldMsg != null && oldMsg.deleted));
|
FileLog.d("processDialogsUpdate oldMsgDeleted " + (oldMsg != null && oldMsg.deleted));
|
||||||
}
|
}
|
||||||
if (oldMsg == null || currentDialog.top_message > 0) {
|
if (oldMsg == null || currentDialog.top_message > 0) {
|
||||||
|
|
|
@ -83,6 +83,13 @@ public class MessagesStorage extends BaseController {
|
||||||
private CountDownLatch openSync = new CountDownLatch(1);
|
private CountDownLatch openSync = new CountDownLatch(1);
|
||||||
|
|
||||||
private static volatile MessagesStorage[] Instance = new MessagesStorage[UserConfig.MAX_ACCOUNT_COUNT];
|
private static volatile MessagesStorage[] Instance = new MessagesStorage[UserConfig.MAX_ACCOUNT_COUNT];
|
||||||
|
private static final Object[] lockObjects = new Object[UserConfig.MAX_ACCOUNT_COUNT];
|
||||||
|
static {
|
||||||
|
for (int i = 0; i < UserConfig.MAX_ACCOUNT_COUNT; i++) {
|
||||||
|
lockObjects[i] = new Object();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private final static int LAST_DB_VERSION = 98;
|
private final static int LAST_DB_VERSION = 98;
|
||||||
private boolean databaseMigrationInProgress;
|
private boolean databaseMigrationInProgress;
|
||||||
public boolean showClearDatabaseAlert;
|
public boolean showClearDatabaseAlert;
|
||||||
|
@ -91,7 +98,7 @@ public class MessagesStorage extends BaseController {
|
||||||
public static MessagesStorage getInstance(int num) {
|
public static MessagesStorage getInstance(int num) {
|
||||||
MessagesStorage localInstance = Instance[num];
|
MessagesStorage localInstance = Instance[num];
|
||||||
if (localInstance == null) {
|
if (localInstance == null) {
|
||||||
synchronized (MessagesStorage.class) {
|
synchronized (lockObjects[num]) {
|
||||||
localInstance = Instance[num];
|
localInstance = Instance[num];
|
||||||
if (localInstance == null) {
|
if (localInstance == null) {
|
||||||
Instance[num] = localInstance = new MessagesStorage(num);
|
Instance[num] = localInstance = new MessagesStorage(num);
|
||||||
|
@ -10411,6 +10418,7 @@ public class MessagesStorage extends BaseController {
|
||||||
state.step();
|
state.step();
|
||||||
state.dispose();
|
state.dispose();
|
||||||
getMessagesStorage().getDatabase().commitTransaction();
|
getMessagesStorage().getDatabase().commitTransaction();
|
||||||
|
data.reuse();
|
||||||
}
|
}
|
||||||
|
|
||||||
deleteFromDownloadQueue(idsToDelete, true);
|
deleteFromDownloadQueue(idsToDelete, true);
|
||||||
|
|
|
@ -142,11 +142,17 @@ public class NotificationsController extends BaseController {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static volatile NotificationsController[] Instance = new NotificationsController[UserConfig.MAX_ACCOUNT_COUNT];
|
private static volatile NotificationsController[] Instance = new NotificationsController[UserConfig.MAX_ACCOUNT_COUNT];
|
||||||
|
private static final Object[] lockObjects = new Object[UserConfig.MAX_ACCOUNT_COUNT];
|
||||||
|
static {
|
||||||
|
for (int i = 0; i < UserConfig.MAX_ACCOUNT_COUNT; i++) {
|
||||||
|
lockObjects[i] = new Object();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static NotificationsController getInstance(int num) {
|
public static NotificationsController getInstance(int num) {
|
||||||
NotificationsController localInstance = Instance[num];
|
NotificationsController localInstance = Instance[num];
|
||||||
if (localInstance == null) {
|
if (localInstance == null) {
|
||||||
synchronized (NotificationsController.class) {
|
synchronized (lockObjects[num]) {
|
||||||
localInstance = Instance[num];
|
localInstance = Instance[num];
|
||||||
if (localInstance == null) {
|
if (localInstance == null) {
|
||||||
Instance[num] = localInstance = new NotificationsController(num);
|
Instance[num] = localInstance = new NotificationsController(num);
|
||||||
|
|
|
@ -348,7 +348,7 @@ public class SharedConfig {
|
||||||
|
|
||||||
preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
||||||
boolean saveToGalleryLegacy = preferences.getBoolean("save_gallery", false);
|
boolean saveToGalleryLegacy = preferences.getBoolean("save_gallery", false);
|
||||||
if (saveToGalleryLegacy) {
|
if (saveToGalleryLegacy && BuildVars.NO_SCOPED_STORAGE) {
|
||||||
saveToGalleryFlags = SAVE_TO_GALLERY_FLAG_PEER + SAVE_TO_GALLERY_FLAG_CHANNELS + SAVE_TO_GALLERY_FLAG_GROUP;
|
saveToGalleryFlags = SAVE_TO_GALLERY_FLAG_PEER + SAVE_TO_GALLERY_FLAG_CHANNELS + SAVE_TO_GALLERY_FLAG_GROUP;
|
||||||
preferences.edit().remove("save_gallery").putInt("save_gallery_flags", saveToGalleryFlags).apply();
|
preferences.edit().remove("save_gallery").putInt("save_gallery_flags", saveToGalleryFlags).apply();
|
||||||
} else {
|
} else {
|
||||||
|
@ -1229,7 +1229,7 @@ public class SharedConfig {
|
||||||
devicePerformanceClass = PERFORMANCE_CLASS_HIGH;
|
devicePerformanceClass = PERFORMANCE_CLASS_HIGH;
|
||||||
}
|
}
|
||||||
if (BuildVars.LOGS_ENABLED) {
|
if (BuildVars.LOGS_ENABLED) {
|
||||||
FileLog.d("device performance info (cpu_count = " + cpuCount + ", freq = " + maxCpuFreq + ", memoryClass = " + memoryClass + ", android version " + androidVersion + ")");
|
FileLog.d("device performance info selected_class = " + devicePerformanceClass + " (cpu_count = " + cpuCount + ", freq = " + maxCpuFreq + ", memoryClass = " + memoryClass + ", android version " + androidVersion + ")");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -31865,6 +31865,9 @@ public class TLRPC {
|
||||||
case 0xdc7b1140:
|
case 0xdc7b1140:
|
||||||
result = new TL_messageEntityMentionName();
|
result = new TL_messageEntityMentionName();
|
||||||
break;
|
break;
|
||||||
|
case 0xd4a00ed5:
|
||||||
|
result = new TL_messageEntityCustomEmoji();
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
if (result == null && exception) {
|
if (result == null && exception) {
|
||||||
throw new RuntimeException(String.format("can't parse magic %x in MessageEntity", constructor));
|
throw new RuntimeException(String.format("can't parse magic %x in MessageEntity", constructor));
|
||||||
|
@ -60296,6 +60299,30 @@ public class TLRPC {
|
||||||
invoice_media.serializeToStream(stream);
|
invoice_media.serializeToStream(stream);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static class TL_messageEntityCustomEmoji extends MessageEntity {
|
||||||
|
public static int constructor = 0xd4a00ed5;
|
||||||
|
|
||||||
|
public int offset;
|
||||||
|
public int length;
|
||||||
|
public InputStickerSet stickerset;
|
||||||
|
public long document_id;
|
||||||
|
|
||||||
|
public void readParams(AbstractSerializedData stream, boolean exception) {
|
||||||
|
offset = stream.readInt32(exception);
|
||||||
|
length = stream.readInt32(exception);
|
||||||
|
stickerset = InputStickerSet.TLdeserialize(stream, stream.readInt32(exception), exception);
|
||||||
|
document_id = stream.readInt64(exception);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void serializeToStream(AbstractSerializedData stream) {
|
||||||
|
stream.writeInt32(constructor);
|
||||||
|
stream.writeInt32(offset);
|
||||||
|
stream.writeInt32(length);
|
||||||
|
stickerset.serializeToStream(stream);
|
||||||
|
stream.writeInt64(document_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
//functions
|
//functions
|
||||||
|
|
||||||
public static class Vector extends TLObject {
|
public static class Vector extends TLObject {
|
||||||
|
|
|
@ -283,8 +283,12 @@ public class CacheControlActivity extends BaseFragment implements NotificationCe
|
||||||
Utilities.globalQueue.postRunnable(() -> {
|
Utilities.globalQueue.postRunnable(() -> {
|
||||||
boolean imagesCleared = false;
|
boolean imagesCleared = false;
|
||||||
long clearedSize = 0;
|
long clearedSize = 0;
|
||||||
|
boolean allItemsClear = true;
|
||||||
for (int a = 0; a < 7; a++) {
|
for (int a = 0; a < 7; a++) {
|
||||||
if (clearViewData[a] == null || !clearViewData[a].clear) {
|
if (clearViewData[a] == null || !clearViewData[a].clear) {
|
||||||
|
if (clearViewData[a] != null) {
|
||||||
|
allItemsClear = false;
|
||||||
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
int type = -1;
|
int type = -1;
|
||||||
|
@ -398,6 +402,9 @@ public class CacheControlActivity extends BaseFragment implements NotificationCe
|
||||||
totalDeviceFreeSize = availableBlocks * blockSize;
|
totalDeviceFreeSize = availableBlocks * blockSize;
|
||||||
long finalClearedSize = clearedSize;
|
long finalClearedSize = clearedSize;
|
||||||
|
|
||||||
|
if (allItemsClear) {
|
||||||
|
FileLoader.getInstance(currentAccount).clearFilePaths();
|
||||||
|
}
|
||||||
FileLoader.getInstance(currentAccount).checkCurrentDownloadsFiles();
|
FileLoader.getInstance(currentAccount).checkCurrentDownloadsFiles();
|
||||||
|
|
||||||
AndroidUtilities.runOnUIThread(() -> {
|
AndroidUtilities.runOnUIThread(() -> {
|
||||||
|
|
|
@ -199,6 +199,57 @@ public class ChatMessageCell extends BaseCell implements SeekBar.SeekBarDelegate
|
||||||
setSpoilersSuppressed(false);
|
setSpoilersSuppressed(false);
|
||||||
} else if (id == NotificationCenter.stopSpoilers) {
|
} else if (id == NotificationCenter.stopSpoilers) {
|
||||||
setSpoilersSuppressed(true);
|
setSpoilersSuppressed(true);
|
||||||
|
} else if (id == NotificationCenter.userInfoDidLoad) {
|
||||||
|
if (currentUser != null) {
|
||||||
|
Long uid = (Long) args[0];
|
||||||
|
if (currentUser.id == uid) {
|
||||||
|
setAvatar(currentMessageObject);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setAvatar(MessageObject messageObject) {
|
||||||
|
if (messageObject == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (isAvatarVisible) {
|
||||||
|
if (messageObject.customAvatarDrawable != null) {
|
||||||
|
avatarImage.setImageBitmap(messageObject.customAvatarDrawable);
|
||||||
|
} else if (currentUser != null) {
|
||||||
|
if (currentUser.photo != null) {
|
||||||
|
currentPhoto = currentUser.photo.photo_small;
|
||||||
|
} else {
|
||||||
|
currentPhoto = null;
|
||||||
|
}
|
||||||
|
avatarDrawable.setInfo(currentUser);
|
||||||
|
avatarImage.setForUserOrChat(currentUser, avatarDrawable, null, true);
|
||||||
|
} else if (currentChat != null) {
|
||||||
|
if (currentChat.photo != null) {
|
||||||
|
currentPhoto = currentChat.photo.photo_small;
|
||||||
|
} else {
|
||||||
|
currentPhoto = null;
|
||||||
|
}
|
||||||
|
avatarDrawable.setInfo(currentChat);
|
||||||
|
avatarImage.setForUserOrChat(currentChat, avatarDrawable);
|
||||||
|
} else if (messageObject != null && messageObject.isSponsored()) {
|
||||||
|
if (messageObject.sponsoredChatInvite != null && messageObject.sponsoredChatInvite.chat != null) {
|
||||||
|
avatarDrawable.setInfo(messageObject.sponsoredChatInvite.chat);
|
||||||
|
avatarImage.setForUserOrChat(messageObject.sponsoredChatInvite.chat, avatarDrawable);
|
||||||
|
} else {
|
||||||
|
avatarDrawable.setInfo(messageObject.sponsoredChatInvite);
|
||||||
|
TLRPC.Photo photo = messageObject.sponsoredChatInvite.photo;
|
||||||
|
if (photo != null) {
|
||||||
|
avatarImage.setImage(ImageLocation.getForPhoto(photo.sizes.get(0), photo), "50_50", avatarDrawable, null, null, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
currentPhoto = null;
|
||||||
|
avatarDrawable.setInfo(messageObject.getFromChatId(), null, null);
|
||||||
|
avatarImage.setImage(null, null, avatarDrawable, null, null, 0);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
currentPhoto = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3356,6 +3407,7 @@ public class ChatMessageCell extends BaseCell implements SeekBar.SeekBarDelegate
|
||||||
|
|
||||||
NotificationCenter.getGlobalInstance().removeObserver(this, NotificationCenter.startSpoilers);
|
NotificationCenter.getGlobalInstance().removeObserver(this, NotificationCenter.startSpoilers);
|
||||||
NotificationCenter.getGlobalInstance().removeObserver(this, NotificationCenter.stopSpoilers);
|
NotificationCenter.getGlobalInstance().removeObserver(this, NotificationCenter.stopSpoilers);
|
||||||
|
NotificationCenter.getInstance(currentAccount).removeObserver(this, NotificationCenter.userInfoDidLoad);
|
||||||
|
|
||||||
cancelShakeAnimation();
|
cancelShakeAnimation();
|
||||||
if (animationRunning) {
|
if (animationRunning) {
|
||||||
|
@ -3423,6 +3475,7 @@ public class ChatMessageCell extends BaseCell implements SeekBar.SeekBarDelegate
|
||||||
|
|
||||||
NotificationCenter.getGlobalInstance().addObserver(this, NotificationCenter.startSpoilers);
|
NotificationCenter.getGlobalInstance().addObserver(this, NotificationCenter.startSpoilers);
|
||||||
NotificationCenter.getGlobalInstance().addObserver(this, NotificationCenter.stopSpoilers);
|
NotificationCenter.getGlobalInstance().addObserver(this, NotificationCenter.stopSpoilers);
|
||||||
|
NotificationCenter.getInstance(currentAccount).addObserver(this, NotificationCenter.userInfoDidLoad);
|
||||||
|
|
||||||
if (currentMessageObject != null) {
|
if (currentMessageObject != null) {
|
||||||
currentMessageObject.animateComments = false;
|
currentMessageObject.animateComments = false;
|
||||||
|
@ -3456,6 +3509,9 @@ public class ChatMessageCell extends BaseCell implements SeekBar.SeekBarDelegate
|
||||||
videoRadialProgress.onAttachedToWindow();
|
videoRadialProgress.onAttachedToWindow();
|
||||||
avatarImage.setParentView((View) getParent());
|
avatarImage.setParentView((View) getParent());
|
||||||
avatarImage.onAttachedToWindow();
|
avatarImage.onAttachedToWindow();
|
||||||
|
if (currentMessageObject != null) {
|
||||||
|
setAvatar(currentMessageObject);
|
||||||
|
}
|
||||||
if (pollAvatarImages != null) {
|
if (pollAvatarImages != null) {
|
||||||
for (int a = 0; a < pollAvatarImages.length; a++) {
|
for (int a = 0; a < pollAvatarImages.length; a++) {
|
||||||
pollAvatarImages[a].onAttachedToWindow();
|
pollAvatarImages[a].onAttachedToWindow();
|
||||||
|
@ -10646,46 +10702,7 @@ public class ChatMessageCell extends BaseCell implements SeekBar.SeekBarDelegate
|
||||||
}
|
}
|
||||||
|
|
||||||
updateCurrentUserAndChat();
|
updateCurrentUserAndChat();
|
||||||
|
setAvatar(messageObject);
|
||||||
if (isAvatarVisible) {
|
|
||||||
if (messageObject.customAvatarDrawable != null) {
|
|
||||||
avatarImage.setImageBitmap(messageObject.customAvatarDrawable);
|
|
||||||
} else if (currentUser != null) {
|
|
||||||
if (currentUser.photo != null) {
|
|
||||||
currentPhoto = currentUser.photo.photo_small;
|
|
||||||
} else {
|
|
||||||
currentPhoto = null;
|
|
||||||
}
|
|
||||||
avatarDrawable.setInfo(currentUser);
|
|
||||||
avatarImage.setForUserOrChat(currentUser, avatarDrawable, null, true);
|
|
||||||
} else if (currentChat != null) {
|
|
||||||
if (currentChat.photo != null) {
|
|
||||||
currentPhoto = currentChat.photo.photo_small;
|
|
||||||
} else {
|
|
||||||
currentPhoto = null;
|
|
||||||
}
|
|
||||||
avatarDrawable.setInfo(currentChat);
|
|
||||||
avatarImage.setForUserOrChat(currentChat, avatarDrawable);
|
|
||||||
} else if (messageObject != null && messageObject.isSponsored()) {
|
|
||||||
if (messageObject.sponsoredChatInvite != null && messageObject.sponsoredChatInvite.chat != null) {
|
|
||||||
avatarDrawable.setInfo(messageObject.sponsoredChatInvite.chat);
|
|
||||||
avatarImage.setForUserOrChat(messageObject.sponsoredChatInvite.chat, avatarDrawable);
|
|
||||||
} else {
|
|
||||||
avatarDrawable.setInfo(messageObject.sponsoredChatInvite);
|
|
||||||
TLRPC.Photo photo = messageObject.sponsoredChatInvite.photo;
|
|
||||||
if (photo != null) {
|
|
||||||
avatarImage.setImage(ImageLocation.getForPhoto(photo.sizes.get(0), photo), "50_50", avatarDrawable, null, null, 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
currentPhoto = null;
|
|
||||||
avatarDrawable.setInfo(messageObject.getFromChatId(), null, null);
|
|
||||||
avatarImage.setImage(null, null, avatarDrawable, null, null, 0);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
currentPhoto = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
measureTime(messageObject);
|
measureTime(messageObject);
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,6 @@ import android.text.style.CharacterStyle;
|
||||||
import android.text.style.ClickableSpan;
|
import android.text.style.ClickableSpan;
|
||||||
import android.text.style.ReplacementSpan;
|
import android.text.style.ReplacementSpan;
|
||||||
import android.text.style.StyleSpan;
|
import android.text.style.StyleSpan;
|
||||||
import android.util.Log;
|
|
||||||
import android.view.HapticFeedbackConstants;
|
import android.view.HapticFeedbackConstants;
|
||||||
import android.view.accessibility.AccessibilityEvent;
|
import android.view.accessibility.AccessibilityEvent;
|
||||||
import android.view.accessibility.AccessibilityNodeInfo;
|
import android.view.accessibility.AccessibilityNodeInfo;
|
||||||
|
@ -2064,31 +2063,29 @@ public class DialogCell extends BaseCell {
|
||||||
if (isDialogCell) {
|
if (isDialogCell) {
|
||||||
TLRPC.Dialog dialog = MessagesController.getInstance(currentAccount).dialogs_dict.get(currentDialogId);
|
TLRPC.Dialog dialog = MessagesController.getInstance(currentAccount).dialogs_dict.get(currentDialogId);
|
||||||
if (dialog != null) {
|
if (dialog != null) {
|
||||||
if (mask == 0) {
|
clearingDialog = MessagesController.getInstance(currentAccount).isClearingDialog(dialog.id);
|
||||||
clearingDialog = MessagesController.getInstance(currentAccount).isClearingDialog(dialog.id);
|
message = MessagesController.getInstance(currentAccount).dialogMessage.get(dialog.id);
|
||||||
message = MessagesController.getInstance(currentAccount).dialogMessage.get(dialog.id);
|
lastUnreadState = message != null && message.isUnread();
|
||||||
lastUnreadState = message != null && message.isUnread();
|
if (dialog instanceof TLRPC.TL_dialogFolder) {
|
||||||
if (dialog instanceof TLRPC.TL_dialogFolder) {
|
unreadCount = MessagesStorage.getInstance(currentAccount).getArchiveUnreadCount();
|
||||||
unreadCount = MessagesStorage.getInstance(currentAccount).getArchiveUnreadCount();
|
mentionCount = 0;
|
||||||
mentionCount = 0;
|
reactionMentionCount = 0;
|
||||||
reactionMentionCount = 0;
|
} else {
|
||||||
} else {
|
unreadCount = dialog.unread_count;
|
||||||
unreadCount = dialog.unread_count;
|
mentionCount = dialog.unread_mentions_count;
|
||||||
mentionCount = dialog.unread_mentions_count;
|
reactionMentionCount = dialog.unread_reactions_count;
|
||||||
reactionMentionCount = dialog.unread_reactions_count;
|
}
|
||||||
}
|
markUnread = dialog.unread_mark;
|
||||||
markUnread = dialog.unread_mark;
|
currentEditDate = message != null ? message.messageOwner.edit_date : 0;
|
||||||
currentEditDate = message != null ? message.messageOwner.edit_date : 0;
|
lastMessageDate = dialog.last_message_date;
|
||||||
lastMessageDate = dialog.last_message_date;
|
if (dialogsType == 7 || dialogsType == 8) {
|
||||||
if (dialogsType == 7 || dialogsType == 8) {
|
MessagesController.DialogFilter filter = MessagesController.getInstance(currentAccount).selectedDialogFilter[dialogsType == 8 ? 1 : 0];
|
||||||
MessagesController.DialogFilter filter = MessagesController.getInstance(currentAccount).selectedDialogFilter[dialogsType == 8 ? 1 : 0];
|
drawPin = filter != null && filter.pinnedDialogs.indexOfKey(dialog.id) >= 0;
|
||||||
drawPin = filter != null && filter.pinnedDialogs.indexOfKey(dialog.id) >= 0;
|
} else {
|
||||||
} else {
|
drawPin = currentDialogFolderId == 0 && dialog.pinned;
|
||||||
drawPin = currentDialogFolderId == 0 && dialog.pinned;
|
}
|
||||||
}
|
if (message != null) {
|
||||||
if (message != null) {
|
lastSendState = message.messageOwner.send_state;
|
||||||
lastSendState = message.messageOwner.send_state;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
unreadCount = 0;
|
unreadCount = 0;
|
||||||
|
|
|
@ -61,7 +61,6 @@ import android.text.TextUtils;
|
||||||
import android.text.style.CharacterStyle;
|
import android.text.style.CharacterStyle;
|
||||||
import android.text.style.ForegroundColorSpan;
|
import android.text.style.ForegroundColorSpan;
|
||||||
import android.text.style.URLSpan;
|
import android.text.style.URLSpan;
|
||||||
import android.util.Log;
|
|
||||||
import android.util.Property;
|
import android.util.Property;
|
||||||
import android.util.SparseArray;
|
import android.util.SparseArray;
|
||||||
import android.util.SparseIntArray;
|
import android.util.SparseIntArray;
|
||||||
|
@ -543,6 +542,7 @@ ChatActivity extends BaseFragment implements NotificationCenter.NotificationCent
|
||||||
private boolean allowContextBotPanel;
|
private boolean allowContextBotPanel;
|
||||||
private boolean allowContextBotPanelSecond = true;
|
private boolean allowContextBotPanelSecond = true;
|
||||||
private AnimatorSet runningAnimation;
|
private AnimatorSet runningAnimation;
|
||||||
|
private int runningAnimationIndex = -1;
|
||||||
|
|
||||||
private MessageObject selectedObjectToEditCaption;
|
private MessageObject selectedObjectToEditCaption;
|
||||||
private MessageObject selectedObject;
|
private MessageObject selectedObject;
|
||||||
|
@ -6543,7 +6543,7 @@ ChatActivity extends BaseFragment implements NotificationCenter.NotificationCent
|
||||||
reactionsMentiondownButton = new FrameLayout(context);
|
reactionsMentiondownButton = new FrameLayout(context);
|
||||||
contentView.addView(reactionsMentiondownButton, LayoutHelper.createFrame(46, 61, Gravity.RIGHT | Gravity.BOTTOM, 0, 0, 7, 5));
|
contentView.addView(reactionsMentiondownButton, LayoutHelper.createFrame(46, 61, Gravity.RIGHT | Gravity.BOTTOM, 0, 0, 7, 5));
|
||||||
|
|
||||||
mentionContainer = new MentionsContainerView(context, dialog_id, threadMessageId, contentView, themeDelegate) {
|
mentionContainer = new MentionsContainerView(context, dialog_id, threadMessageId, ChatActivity.this, themeDelegate) {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected boolean canOpen() {
|
protected boolean canOpen() {
|
||||||
|
@ -10023,9 +10023,11 @@ ChatActivity extends BaseFragment implements NotificationCenter.NotificationCent
|
||||||
ObjectAnimator.ofFloat(stickersPanel, View.ALPHA, show ? 0.0f : 1.0f, show ? 1.0f : 0.0f)
|
ObjectAnimator.ofFloat(stickersPanel, View.ALPHA, show ? 0.0f : 1.0f, show ? 1.0f : 0.0f)
|
||||||
);
|
);
|
||||||
runningAnimation.setDuration(150);
|
runningAnimation.setDuration(150);
|
||||||
|
runningAnimationIndex = getNotificationCenter().setAnimationInProgress(runningAnimationIndex, null);
|
||||||
runningAnimation.addListener(new AnimatorListenerAdapter() {
|
runningAnimation.addListener(new AnimatorListenerAdapter() {
|
||||||
@Override
|
@Override
|
||||||
public void onAnimationEnd(Animator animation) {
|
public void onAnimationEnd(Animator animation) {
|
||||||
|
getNotificationCenter().onAnimationFinish(runningAnimationIndex);
|
||||||
if (runningAnimation != null && runningAnimation.equals(animation)) {
|
if (runningAnimation != null && runningAnimation.equals(animation)) {
|
||||||
if (!show) {
|
if (!show) {
|
||||||
stickersAdapter.clearSearch();
|
stickersAdapter.clearSearch();
|
||||||
|
|
|
@ -146,6 +146,7 @@ public class AnimatedFileDrawable extends BitmapDrawable implements Animatable {
|
||||||
public int repeatCount;
|
public int repeatCount;
|
||||||
|
|
||||||
private static ScheduledThreadPoolExecutor executor = new ScheduledThreadPoolExecutor(8, new ThreadPoolExecutor.DiscardPolicy());
|
private static ScheduledThreadPoolExecutor executor = new ScheduledThreadPoolExecutor(8, new ThreadPoolExecutor.DiscardPolicy());
|
||||||
|
private static ScheduledThreadPoolExecutor generateCache = new ScheduledThreadPoolExecutor(4, new ThreadPoolExecutor.DiscardPolicy());
|
||||||
|
|
||||||
private Runnable uiRunnableNoFrame = new Runnable() {
|
private Runnable uiRunnableNoFrame = new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -191,8 +191,12 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
|
|
||||||
private FloatBuffer vertexBuffer;
|
private FloatBuffer vertexBuffer;
|
||||||
private FloatBuffer textureBuffer;
|
private FloatBuffer textureBuffer;
|
||||||
|
private FloatBuffer oldTextureTextureBuffer;
|
||||||
private float scaleX;
|
private float scaleX;
|
||||||
private float scaleY;
|
private float scaleY;
|
||||||
|
|
||||||
|
private Size oldTexturePreviewSize;
|
||||||
|
|
||||||
private boolean flipAnimationInProgress;
|
private boolean flipAnimationInProgress;
|
||||||
|
|
||||||
private View parentView;
|
private View parentView;
|
||||||
|
@ -543,7 +547,6 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.LOLLIPOP) {
|
if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.LOLLIPOP) {
|
||||||
switchCameraDrawable = (AnimatedVectorDrawable) ContextCompat.getDrawable(getContext(), R.drawable.avd_flip);
|
switchCameraDrawable = (AnimatedVectorDrawable) ContextCompat.getDrawable(getContext(), R.drawable.avd_flip);
|
||||||
switchCameraButton.setImageDrawable(switchCameraDrawable);
|
switchCameraButton.setImageDrawable(switchCameraDrawable);
|
||||||
|
@ -610,7 +613,11 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onSurfaceTextureSizeChanged(SurfaceTexture surface, final int width, final int height) {
|
public void onSurfaceTextureSizeChanged(SurfaceTexture surface, final int width, final int height) {
|
||||||
|
if (cameraThread != null) {
|
||||||
|
cameraThread.surfaceWidth = width;
|
||||||
|
cameraThread.surfaceHeight = height;
|
||||||
|
cameraThread.updateScale();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -969,21 +976,21 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
private Size chooseOptimalSize(ArrayList<Size> previewSizes) {
|
private Size chooseOptimalSize(ArrayList<Size> previewSizes) {
|
||||||
ArrayList<Size> sortedSizes = new ArrayList<>();
|
ArrayList<Size> sortedSizes = new ArrayList<>();
|
||||||
for (int i = 0; i < previewSizes.size(); i++) {
|
for (int i = 0; i < previewSizes.size(); i++) {
|
||||||
if (Math.max(previewSizes.get(i).mHeight, previewSizes.get(i).mHeight) <= 1200 && Math.min(previewSizes.get(i).mHeight, previewSizes.get(i).mHeight) >= 320) {
|
if (Math.max(previewSizes.get(i).mHeight, previewSizes.get(i).mWidth) <= 1200 && Math.min(previewSizes.get(i).mHeight, previewSizes.get(i).mWidth) >= 320) {
|
||||||
sortedSizes.add(previewSizes.get(i));
|
sortedSizes.add(previewSizes.get(i));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (sortedSizes.isEmpty() || SharedConfig.getDevicePerformanceClass() == SharedConfig.PERFORMANCE_CLASS_LOW) {
|
if (sortedSizes.isEmpty() || SharedConfig.getDevicePerformanceClass() == SharedConfig.PERFORMANCE_CLASS_LOW || SharedConfig.getDevicePerformanceClass() == SharedConfig.PERFORMANCE_CLASS_AVERAGE) {
|
||||||
return CameraController.chooseOptimalSize(previewSizes, 480, 270, aspectRatio);
|
return CameraController.chooseOptimalSize(previewSizes, 480, 270, aspectRatio);
|
||||||
}
|
}
|
||||||
Collections.sort(sortedSizes, (o1, o2) -> {
|
Collections.sort(sortedSizes, (o1, o2) -> {
|
||||||
float a1 = Math.min(o1.mHeight, o1.mWidth) / (float) Math.max(o1.mHeight, o1.mWidth);
|
float a1 = Math.abs(1f - Math.min(o1.mHeight, o1.mWidth) / (float) Math.max(o1.mHeight, o1.mWidth));
|
||||||
float a2 = Math.min(o2.mHeight, o2.mWidth) / (float) Math.max(o2.mHeight, o2.mWidth);
|
float a2 = Math.abs(1f - Math.min(o2.mHeight, o2.mWidth) / (float) Math.max(o2.mHeight, o2.mWidth));
|
||||||
|
|
||||||
if (a1 < a2) {
|
if (a1 < a2) {
|
||||||
return 1;
|
|
||||||
} else if (a1 > a2) {
|
|
||||||
return -1;
|
return -1;
|
||||||
|
} else if (a1 > a2) {
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
});
|
});
|
||||||
|
@ -1129,10 +1136,20 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
|
|
||||||
private VideoRecorder videoEncoder;
|
private VideoRecorder videoEncoder;
|
||||||
|
|
||||||
|
private int surfaceWidth;
|
||||||
|
private int surfaceHeight;
|
||||||
|
|
||||||
public CameraGLThread(SurfaceTexture surface, int surfaceWidth, int surfaceHeight) {
|
public CameraGLThread(SurfaceTexture surface, int surfaceWidth, int surfaceHeight) {
|
||||||
super("CameraGLThread");
|
super("CameraGLThread");
|
||||||
surfaceTexture = surface;
|
surfaceTexture = surface;
|
||||||
|
|
||||||
|
this.surfaceWidth = surfaceWidth;
|
||||||
|
this.surfaceHeight = surfaceHeight;
|
||||||
|
|
||||||
|
updateScale();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updateScale() {
|
||||||
int width = previewSize.getWidth();
|
int width = previewSize.getWidth();
|
||||||
int height = previewSize.getHeight();
|
int height = previewSize.getHeight();
|
||||||
|
|
||||||
|
@ -1140,13 +1157,19 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
|
|
||||||
width *= scale;
|
width *= scale;
|
||||||
height *= scale;
|
height *= scale;
|
||||||
if (width > height) {
|
|
||||||
|
if (width == height) {
|
||||||
|
scaleX = 1f;
|
||||||
|
scaleY = 1f;
|
||||||
|
} else if (width > height) {
|
||||||
scaleX = 1.0f;
|
scaleX = 1.0f;
|
||||||
scaleY = width / (float) surfaceHeight;
|
scaleY = width / (float) surfaceHeight;
|
||||||
} else {
|
} else {
|
||||||
scaleX = height / (float) surfaceWidth;
|
scaleX = height / (float) surfaceWidth;
|
||||||
scaleY = 1.0f;
|
scaleY = 1.0f;
|
||||||
}
|
}
|
||||||
|
FileLog.d("camera scaleX = " + scaleX + " scaleY = " + scaleY);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean initGL() {
|
private boolean initGL() {
|
||||||
|
@ -1313,6 +1336,7 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
if (handler != null) {
|
if (handler != null) {
|
||||||
sendMessage(handler.obtainMessage(DO_REINIT_MESSAGE), 0);
|
sendMessage(handler.obtainMessage(DO_REINIT_MESSAGE), 0);
|
||||||
}
|
}
|
||||||
|
updateScale();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void finish() {
|
public void finish() {
|
||||||
|
@ -1430,6 +1454,8 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
oldCameraTexture[0] = cameraTexture[0];
|
oldCameraTexture[0] = cameraTexture[0];
|
||||||
cameraTextureAlpha = 0.0f;
|
cameraTextureAlpha = 0.0f;
|
||||||
cameraTexture[0] = 0;
|
cameraTexture[0] = 0;
|
||||||
|
oldTextureTextureBuffer = textureBuffer.duplicate();
|
||||||
|
oldTexturePreviewSize = previewSize;
|
||||||
}
|
}
|
||||||
cameraId++;
|
cameraId++;
|
||||||
cameraReady = false;
|
cameraReady = false;
|
||||||
|
@ -1444,6 +1470,21 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
cameraSurface = new SurfaceTexture(cameraTexture[0]);
|
cameraSurface = new SurfaceTexture(cameraTexture[0]);
|
||||||
cameraSurface.setOnFrameAvailableListener(surfaceTexture -> requestRender());
|
cameraSurface.setOnFrameAvailableListener(surfaceTexture -> requestRender());
|
||||||
createCamera(cameraSurface);
|
createCamera(cameraSurface);
|
||||||
|
|
||||||
|
cameraThread.updateScale();
|
||||||
|
|
||||||
|
float tX = 1.0f / scaleX / 2.0f;
|
||||||
|
float tY = 1.0f / scaleY / 2.0f;
|
||||||
|
|
||||||
|
float[] texData = {
|
||||||
|
0.5f - tX, 0.5f - tY,
|
||||||
|
0.5f + tX, 0.5f - tY,
|
||||||
|
0.5f - tX, 0.5f + tY,
|
||||||
|
0.5f + tX, 0.5f + tY
|
||||||
|
};
|
||||||
|
|
||||||
|
textureBuffer = ByteBuffer.allocateDirect(texData.length * 4).order(ByteOrder.nativeOrder()).asFloatBuffer();
|
||||||
|
textureBuffer.put(texData).position(0);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case DO_SETSESSION_MESSAGE: {
|
case DO_SETSESSION_MESSAGE: {
|
||||||
|
@ -1618,8 +1659,8 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
private int textureMatrixHandle;
|
private int textureMatrixHandle;
|
||||||
private int positionHandle;
|
private int positionHandle;
|
||||||
private int textureHandle;
|
private int textureHandle;
|
||||||
private int scaleXHandle;
|
private int resolutionHandle;
|
||||||
private int scaleYHandle;
|
private int previewSizeHandle;
|
||||||
private int alphaHandle;
|
private int alphaHandle;
|
||||||
private int zeroTimeStamps;
|
private int zeroTimeStamps;
|
||||||
private Integer lastCameraId = 0;
|
private Integer lastCameraId = 0;
|
||||||
|
@ -1956,25 +1997,38 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
videoLast = timestampNanos;
|
videoLast = timestampNanos;
|
||||||
|
|
||||||
GLES20.glUseProgram(drawProgram);
|
GLES20.glUseProgram(drawProgram);
|
||||||
GLES20.glVertexAttribPointer(positionHandle, 3, GLES20.GL_FLOAT, false, 12, vertexBuffer);
|
|
||||||
GLES20.glEnableVertexAttribArray(positionHandle);
|
|
||||||
GLES20.glVertexAttribPointer(textureHandle, 2, GLES20.GL_FLOAT, false, 8, textureBuffer);
|
|
||||||
GLES20.glEnableVertexAttribArray(textureHandle);
|
|
||||||
GLES20.glUniform1f(scaleXHandle, scaleX);
|
|
||||||
GLES20.glUniform1f(scaleYHandle, scaleY);
|
|
||||||
GLES20.glUniformMatrix4fv(vertexMatrixHandle, 1, false, mMVPMatrix, 0);
|
GLES20.glUniformMatrix4fv(vertexMatrixHandle, 1, false, mMVPMatrix, 0);
|
||||||
|
|
||||||
GLES20.glActiveTexture(GLES20.GL_TEXTURE0);
|
GLES20.glActiveTexture(GLES20.GL_TEXTURE0);
|
||||||
|
GLES20.glEnableVertexAttribArray(positionHandle);
|
||||||
|
GLES20.glEnableVertexAttribArray(textureHandle);
|
||||||
|
|
||||||
|
GLES20.glUniform2f(resolutionHandle, videoWidth, videoHeight);
|
||||||
|
|
||||||
if (oldCameraTexture[0] != 0) {
|
if (oldCameraTexture[0] != 0) {
|
||||||
if (!blendEnabled) {
|
if (!blendEnabled) {
|
||||||
GLES20.glEnable(GLES20.GL_BLEND);
|
GLES20.glEnable(GLES20.GL_BLEND);
|
||||||
blendEnabled = true;
|
blendEnabled = true;
|
||||||
}
|
}
|
||||||
|
if (oldTexturePreviewSize != null) {
|
||||||
|
GLES20.glUniform2f(previewSizeHandle, oldTexturePreviewSize.getWidth(), oldTexturePreviewSize.getHeight());
|
||||||
|
}
|
||||||
|
GLES20.glVertexAttribPointer(textureHandle, 2, GLES20.GL_FLOAT, false, 8, oldTextureTextureBuffer);
|
||||||
|
|
||||||
GLES20.glUniformMatrix4fv(textureMatrixHandle, 1, false, moldSTMatrix, 0);
|
GLES20.glUniformMatrix4fv(textureMatrixHandle, 1, false, moldSTMatrix, 0);
|
||||||
GLES20.glUniform1f(alphaHandle, 1.0f);
|
GLES20.glUniform1f(alphaHandle, 1.0f);
|
||||||
GLES20.glBindTexture(GLES11Ext.GL_TEXTURE_EXTERNAL_OES, oldCameraTexture[0]);
|
GLES20.glBindTexture(GLES11Ext.GL_TEXTURE_EXTERNAL_OES, oldCameraTexture[0]);
|
||||||
GLES20.glDrawArrays(GLES20.GL_TRIANGLE_STRIP, 0, 4);
|
GLES20.glDrawArrays(GLES20.GL_TRIANGLE_STRIP, 0, 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (previewSize != null) {
|
||||||
|
GLES20.glUniform2f(previewSizeHandle, previewSize.getWidth(), previewSize.getHeight());
|
||||||
|
}
|
||||||
|
|
||||||
|
GLES20.glVertexAttribPointer(positionHandle, 3, GLES20.GL_FLOAT, false, 12, vertexBuffer);
|
||||||
|
GLES20.glVertexAttribPointer(textureHandle, 2, GLES20.GL_FLOAT, false, 8, textureBuffer);
|
||||||
|
|
||||||
GLES20.glUniformMatrix4fv(textureMatrixHandle, 1, false, mSTMatrix, 0);
|
GLES20.glUniformMatrix4fv(textureMatrixHandle, 1, false, mSTMatrix, 0);
|
||||||
GLES20.glUniform1f(alphaHandle, cameraTextureAlpha);
|
GLES20.glUniform1f(alphaHandle, cameraTextureAlpha);
|
||||||
GLES20.glBindTexture(GLES11Ext.GL_TEXTURE_EXTERNAL_OES, cameraTexture[0]);
|
GLES20.glBindTexture(GLES11Ext.GL_TEXTURE_EXTERNAL_OES, cameraTexture[0]);
|
||||||
|
@ -2022,14 +2076,19 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
public void run() {
|
public void run() {
|
||||||
final TextureView textureView = InstantCameraView.this.textureView;
|
final TextureView textureView = InstantCameraView.this.textureView;
|
||||||
if (textureView != null) {
|
if (textureView != null) {
|
||||||
final Bitmap bitmap = textureView.getBitmap(AndroidUtilities.dp(56), AndroidUtilities.dp(56));
|
try {
|
||||||
AndroidUtilities.runOnUIThread(() -> {
|
final Bitmap bitmap = textureView.getBitmap(AndroidUtilities.dp(56), AndroidUtilities.dp(56));
|
||||||
if ((bitmap == null || bitmap.getPixel(0, 0) == 0) && keyframeThumbs.size() > 1) {
|
AndroidUtilities.runOnUIThread(() -> {
|
||||||
keyframeThumbs.add(keyframeThumbs.get(keyframeThumbs.size() - 1));
|
if ((bitmap == null || bitmap.getPixel(0, 0) == 0) && keyframeThumbs.size() > 1) {
|
||||||
} else {
|
keyframeThumbs.add(keyframeThumbs.get(keyframeThumbs.size() - 1));
|
||||||
keyframeThumbs.add(bitmap);
|
} else {
|
||||||
}
|
keyframeThumbs.add(bitmap);
|
||||||
});
|
}
|
||||||
|
});
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e(e);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2340,8 +2399,8 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
} else {
|
} else {
|
||||||
positionHandle = GLES20.glGetAttribLocation(drawProgram, "aPosition");
|
positionHandle = GLES20.glGetAttribLocation(drawProgram, "aPosition");
|
||||||
textureHandle = GLES20.glGetAttribLocation(drawProgram, "aTextureCoord");
|
textureHandle = GLES20.glGetAttribLocation(drawProgram, "aTextureCoord");
|
||||||
scaleXHandle = GLES20.glGetUniformLocation(drawProgram, "scaleX");
|
previewSizeHandle = GLES20.glGetUniformLocation(drawProgram, "preview");
|
||||||
scaleYHandle = GLES20.glGetUniformLocation(drawProgram, "scaleY");
|
resolutionHandle = GLES20.glGetUniformLocation(drawProgram, "resolution");
|
||||||
alphaHandle = GLES20.glGetUniformLocation(drawProgram, "alpha");
|
alphaHandle = GLES20.glGetUniformLocation(drawProgram, "alpha");
|
||||||
vertexMatrixHandle = GLES20.glGetUniformLocation(drawProgram, "uMVPMatrix");
|
vertexMatrixHandle = GLES20.glGetUniformLocation(drawProgram, "uMVPMatrix");
|
||||||
textureMatrixHandle = GLES20.glGetUniformLocation(drawProgram, "uSTMatrix");
|
textureMatrixHandle = GLES20.glGetUniformLocation(drawProgram, "uSTMatrix");
|
||||||
|
@ -2534,18 +2593,21 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
}
|
}
|
||||||
|
|
||||||
private String createFragmentShader(Size previewSize) {
|
private String createFragmentShader(Size previewSize) {
|
||||||
if (SharedConfig.getDevicePerformanceClass() == SharedConfig.PERFORMANCE_CLASS_LOW || Math.max(previewSize.getHeight(), previewSize.getWidth()) * 0.7f < MessagesController.getInstance(currentAccount).roundVideoSize) {
|
if (SharedConfig.getDevicePerformanceClass() == SharedConfig.PERFORMANCE_CLASS_LOW || SharedConfig.getDevicePerformanceClass() == SharedConfig.PERFORMANCE_CLASS_AVERAGE || Math.max(previewSize.getHeight(), previewSize.getWidth()) * 0.7f < MessagesController.getInstance(currentAccount).roundVideoSize) {
|
||||||
return "#extension GL_OES_EGL_image_external : require\n" +
|
return "#extension GL_OES_EGL_image_external : require\n" +
|
||||||
"precision highp float;\n" +
|
"precision highp float;\n" +
|
||||||
"varying vec2 vTextureCoord;\n" +
|
"varying vec2 vTextureCoord;\n" +
|
||||||
"uniform float scaleX;\n" +
|
|
||||||
"uniform float scaleY;\n" +
|
|
||||||
"uniform float alpha;\n" +
|
"uniform float alpha;\n" +
|
||||||
|
"uniform vec2 preview;\n" +
|
||||||
|
"uniform vec2 resolution;\n" +
|
||||||
"uniform samplerExternalOES sTexture;\n" +
|
"uniform samplerExternalOES sTexture;\n" +
|
||||||
"void main() {\n" +
|
"void main() {\n" +
|
||||||
" vec2 coord = vec2((vTextureCoord.x - 0.5) * scaleX, (vTextureCoord.y - 0.5) * scaleY);\n" +
|
" vec4 textColor = texture2D(sTexture, vTextureCoord);\n" +
|
||||||
" float coef = ceil(clamp(0.2601 - dot(coord, coord), 0.0, 1.0));\n" +
|
" vec2 coord = resolution * 0.5;\n" +
|
||||||
" vec3 color = texture2D(sTexture, vTextureCoord).rgb * coef + (1.0 - step(0.001, coef));\n" +
|
" float radius = 0.51 * resolution.x;\n" +
|
||||||
|
" float d = length(coord - gl_FragCoord.xy) - radius;\n" +
|
||||||
|
" float t = clamp(d, 0.0, 1.0);\n" +
|
||||||
|
" vec3 color = mix(textColor.rgb, vec3(1, 1, 1), t);\n" +
|
||||||
" gl_FragColor = vec4(color * alpha, alpha);\n" +
|
" gl_FragColor = vec4(color * alpha, alpha);\n" +
|
||||||
"}\n";
|
"}\n";
|
||||||
}
|
}
|
||||||
|
@ -2553,27 +2615,29 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
return "#extension GL_OES_EGL_image_external : require\n" +
|
return "#extension GL_OES_EGL_image_external : require\n" +
|
||||||
"precision highp float;\n" +
|
"precision highp float;\n" +
|
||||||
"varying vec2 vTextureCoord;\n" +
|
"varying vec2 vTextureCoord;\n" +
|
||||||
"uniform float scaleX;\n" +
|
"uniform vec2 resolution;\n" +
|
||||||
"uniform float scaleY;\n" +
|
"uniform vec2 preview;\n" +
|
||||||
"uniform float alpha;\n" +
|
"uniform float alpha;\n" +
|
||||||
"const float kernel = 1.0;\n" +
|
"const float kernel = 1.0;\n" +
|
||||||
"const float pixelSizeX = 1.0 / " + previewSize.getWidth() + ".0;\n" +
|
|
||||||
"const float pixelSizeY = 1.0 / " + previewSize.getHeight() + ".0;\n" +
|
|
||||||
|
|
||||||
"uniform samplerExternalOES sTexture;\n" +
|
"uniform samplerExternalOES sTexture;\n" +
|
||||||
"void main() {\n" +
|
"void main() {\n" +
|
||||||
|
" float pixelSizeX = 1.0 / preview.x;\n" +
|
||||||
|
" float pixelSizeY = 1.0 / preview.y;\n" +
|
||||||
" vec3 accumulation = vec3(0);\n" +
|
" vec3 accumulation = vec3(0);\n" +
|
||||||
" vec3 weightsum = vec3(0);\n" +
|
" vec3 weightsum = vec3(0);\n" +
|
||||||
" for (float x = -kernel; x <= kernel; x++){\n" +
|
" for (float x = -kernel; x < kernel; x++){\n" +
|
||||||
" for (float y = -kernel; y <= kernel; y++){\n" +
|
" for (float y = -kernel; y < kernel; y++){\n" +
|
||||||
" accumulation += texture2D(sTexture, vTextureCoord + vec2(x * pixelSizeX, y * pixelSizeY)).xyz;\n" +
|
" accumulation += texture2D(sTexture, vTextureCoord + vec2(x * pixelSizeX, y * pixelSizeY)).xyz;\n" +
|
||||||
" weightsum += 1.0;\n" +
|
" weightsum += 1.0;\n" +
|
||||||
" }\n" +
|
" }\n" +
|
||||||
" }\n" +
|
" }\n" +
|
||||||
" vec4 textColor = vec4(accumulation / weightsum, 1.0);\n" +
|
" vec4 textColor = vec4(accumulation / weightsum, 1.0);\n" +
|
||||||
" vec2 coord = vec2((vTextureCoord.x - 0.5) * scaleX, (vTextureCoord.y - 0.5) * scaleY);\n" +
|
" vec2 coord = resolution * 0.5;\n" +
|
||||||
" float coef = ceil(clamp(0.2601 - dot(coord, coord), 0.0, 1.0));\n" +
|
" float radius = 0.51 * resolution.x;\n" +
|
||||||
" vec3 color = textColor.rgb * coef + (1.0 - step(0.001, coef));\n" +
|
" float d = length(coord - gl_FragCoord.xy) - radius;\n" +
|
||||||
|
" float t = clamp(d, 0.0, 1.0);\n" +
|
||||||
|
" vec3 color = mix(textColor.rgb, vec3(1, 1, 1), t);\n" +
|
||||||
" gl_FragColor = vec4(color * alpha, alpha);\n" +
|
" gl_FragColor = vec4(color * alpha, alpha);\n" +
|
||||||
"}\n";
|
"}\n";
|
||||||
}
|
}
|
||||||
|
@ -2697,6 +2761,7 @@ public class InstantCameraView extends FrameLayout implements NotificationCenter
|
||||||
}
|
}
|
||||||
|
|
||||||
ValueAnimator finishZoomTransition;
|
ValueAnimator finishZoomTransition;
|
||||||
|
|
||||||
public void finishZoom() {
|
public void finishZoom() {
|
||||||
if (finishZoomTransition != null) {
|
if (finishZoomTransition != null) {
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -2,20 +2,15 @@ package org.telegram.ui.Components;
|
||||||
|
|
||||||
import static org.telegram.messenger.AndroidUtilities.dp;
|
import static org.telegram.messenger.AndroidUtilities.dp;
|
||||||
|
|
||||||
import android.animation.Animator;
|
|
||||||
import android.animation.AnimatorListenerAdapter;
|
|
||||||
import android.animation.ValueAnimator;
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.graphics.Canvas;
|
import android.graphics.Canvas;
|
||||||
import android.graphics.Paint;
|
import android.graphics.Paint;
|
||||||
import android.graphics.Path;
|
import android.graphics.Path;
|
||||||
import android.graphics.Rect;
|
import android.graphics.Rect;
|
||||||
import android.util.Log;
|
|
||||||
import android.view.MotionEvent;
|
import android.view.MotionEvent;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.dynamicanimation.animation.DynamicAnimation;
|
|
||||||
import androidx.dynamicanimation.animation.FloatValueHolder;
|
import androidx.dynamicanimation.animation.FloatValueHolder;
|
||||||
import androidx.dynamicanimation.animation.SpringAnimation;
|
import androidx.dynamicanimation.animation.SpringAnimation;
|
||||||
import androidx.dynamicanimation.animation.SpringForce;
|
import androidx.dynamicanimation.animation.SpringForce;
|
||||||
|
@ -26,12 +21,14 @@ import androidx.recyclerview.widget.RecyclerView;
|
||||||
|
|
||||||
import org.telegram.messenger.AndroidUtilities;
|
import org.telegram.messenger.AndroidUtilities;
|
||||||
import org.telegram.messenger.FileLoader;
|
import org.telegram.messenger.FileLoader;
|
||||||
|
import org.telegram.messenger.NotificationCenter;
|
||||||
import org.telegram.messenger.SharedConfig;
|
import org.telegram.messenger.SharedConfig;
|
||||||
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.tgnet.TLRPC;
|
import org.telegram.tgnet.TLRPC;
|
||||||
import org.telegram.ui.ActionBar.Theme;
|
import org.telegram.ui.ActionBar.Theme;
|
||||||
import org.telegram.ui.Adapters.MentionsAdapter;
|
import org.telegram.ui.Adapters.MentionsAdapter;
|
||||||
import org.telegram.ui.Adapters.PaddedListAdapter;
|
import org.telegram.ui.Adapters.PaddedListAdapter;
|
||||||
import org.telegram.ui.Cells.AboutLinkCell;
|
import org.telegram.ui.ChatActivity;
|
||||||
import org.telegram.ui.ContentPreviewViewer;
|
import org.telegram.ui.ContentPreviewViewer;
|
||||||
|
|
||||||
public class MentionsContainerView extends BlurredFrameLayout {
|
public class MentionsContainerView extends BlurredFrameLayout {
|
||||||
|
@ -45,12 +42,14 @@ public class MentionsContainerView extends BlurredFrameLayout {
|
||||||
|
|
||||||
private PaddedListAdapter paddedAdapter;
|
private PaddedListAdapter paddedAdapter;
|
||||||
private MentionsAdapter adapter;
|
private MentionsAdapter adapter;
|
||||||
|
ChatActivity chatActivity;
|
||||||
|
|
||||||
private float containerTop, containerBottom, containerPadding, listViewPadding;
|
private float containerTop, containerBottom, containerPadding, listViewPadding;
|
||||||
|
|
||||||
public MentionsContainerView(@NonNull Context context, long dialogId, int threadMessageId, SizeNotifierFrameLayout sizeNotifierFrameLayout, Theme.ResourcesProvider resourcesProvider) {
|
public MentionsContainerView(@NonNull Context context, long dialogId, int threadMessageId, ChatActivity chatActivity, Theme.ResourcesProvider resourcesProvider) {
|
||||||
super(context, sizeNotifierFrameLayout);
|
super(context, chatActivity.contentView);
|
||||||
this.sizeNotifierFrameLayout = sizeNotifierFrameLayout;
|
this.chatActivity = chatActivity;
|
||||||
|
this.sizeNotifierFrameLayout = chatActivity.contentView;
|
||||||
this.resourcesProvider = resourcesProvider;
|
this.resourcesProvider = resourcesProvider;
|
||||||
this.drawBlur = false;
|
this.drawBlur = false;
|
||||||
this.isTopView = false;
|
this.isTopView = false;
|
||||||
|
@ -180,7 +179,7 @@ public class MentionsContainerView extends BlurredFrameLayout {
|
||||||
public void onItemCountUpdate(int oldCount, int newCount) {
|
public void onItemCountUpdate(int oldCount, int newCount) {
|
||||||
if (listView.getLayoutManager() != gridLayoutManager && shown) {
|
if (listView.getLayoutManager() != gridLayoutManager && shown) {
|
||||||
AndroidUtilities.cancelRunOnUIThread(updateVisibilityRunnable);
|
AndroidUtilities.cancelRunOnUIThread(updateVisibilityRunnable);
|
||||||
AndroidUtilities.runOnUIThread(updateVisibilityRunnable);
|
AndroidUtilities.runOnUIThread(updateVisibilityRunnable, chatActivity.fragmentOpened ? 0 : 100);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -397,7 +396,7 @@ public class MentionsContainerView extends BlurredFrameLayout {
|
||||||
if (listViewTranslationAnimator != null) {
|
if (listViewTranslationAnimator != null) {
|
||||||
listViewTranslationAnimator.cancel();
|
listViewTranslationAnimator.cancel();
|
||||||
}
|
}
|
||||||
AndroidUtilities.runOnUIThread(updateVisibilityRunnable);
|
AndroidUtilities.runOnUIThread(updateVisibilityRunnable, chatActivity.fragmentOpened ? 0 : 100);
|
||||||
if (show) {
|
if (show) {
|
||||||
onOpen();
|
onOpen();
|
||||||
} else {
|
} else {
|
||||||
|
@ -410,6 +409,7 @@ public class MentionsContainerView extends BlurredFrameLayout {
|
||||||
}
|
}
|
||||||
|
|
||||||
private SpringAnimation listViewTranslationAnimator;
|
private SpringAnimation listViewTranslationAnimator;
|
||||||
|
private int animationIndex = -1;
|
||||||
private boolean listViewHiding = false;
|
private boolean listViewHiding = false;
|
||||||
private float hideT = 0;
|
private float hideT = 0;
|
||||||
private boolean switchLayoutManagerOnEnd = false;
|
private boolean switchLayoutManagerOnEnd = false;
|
||||||
|
@ -451,6 +451,8 @@ public class MentionsContainerView extends BlurredFrameLayout {
|
||||||
updateVisibility(shown = true);
|
updateVisibility(shown = true);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
int account = UserConfig.selectedAccount;
|
||||||
|
animationIndex = NotificationCenter.getInstance(account).setAnimationInProgress(animationIndex, null);
|
||||||
listViewTranslationAnimator =
|
listViewTranslationAnimator =
|
||||||
new SpringAnimation(new FloatValueHolder(fromTranslation))
|
new SpringAnimation(new FloatValueHolder(fromTranslation))
|
||||||
.setSpring(
|
.setSpring(
|
||||||
|
@ -478,6 +480,9 @@ public class MentionsContainerView extends BlurredFrameLayout {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
listViewTranslationAnimator.addEndListener((animation, canceled, value, velocity) -> {
|
||||||
|
NotificationCenter.getInstance(account).onAnimationFinish(animationIndex);
|
||||||
|
});
|
||||||
listViewTranslationAnimator.start();
|
listViewTranslationAnimator.start();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -12,6 +12,9 @@ import android.graphics.Shader;
|
||||||
import android.opengl.GLES20;
|
import android.opengl.GLES20;
|
||||||
import android.opengl.GLUtils;
|
import android.opengl.GLUtils;
|
||||||
|
|
||||||
|
import org.telegram.messenger.R;
|
||||||
|
import org.telegram.messenger.SvgHelper;
|
||||||
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.ui.ActionBar.Theme;
|
import org.telegram.ui.ActionBar.Theme;
|
||||||
|
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
|
@ -143,7 +146,26 @@ public class Star3DIcon {
|
||||||
GLES20.glVertexAttribPointer(0, 3, GLES20.GL_FLOAT, false, 0, mVertices);
|
GLES20.glVertexAttribPointer(0, 3, GLES20.GL_FLOAT, false, 0, mVertices);
|
||||||
GLES20.glEnableVertexAttribArray(0);
|
GLES20.glEnableVertexAttribArray(0);
|
||||||
|
|
||||||
GLES20.glActiveTexture(GLES20.GL_TEXTURE0);
|
|
||||||
|
Bitmap bitmap = SvgHelper.getBitmap(R.raw.start_texture, 80, 80, Color.WHITE);
|
||||||
|
Utilities.stackBlurBitmap(bitmap, 3);
|
||||||
|
|
||||||
|
final int[] texture = new int[1];
|
||||||
|
GLES20.glGenTextures(1, texture, 0);
|
||||||
|
GLES20.glBindTexture(GLES20.GL_TEXTURE_2D, texture[0]);
|
||||||
|
|
||||||
|
GLES20.glTexParameteri(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_MIN_FILTER, GLES20.GL_LINEAR);
|
||||||
|
GLES20.glTexParameteri(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_MAG_FILTER, GLES20.GL_LINEAR);
|
||||||
|
|
||||||
|
GLUtils.texImage2D(GLES20.GL_TEXTURE_2D, 0, bitmap, 0);
|
||||||
|
bitmap.recycle();
|
||||||
|
|
||||||
|
final int[] textureDatHandle = new int[1];
|
||||||
|
GLES20.glGenTextures(1, textureDatHandle, 0);
|
||||||
|
mTextureDataHandle = textureDatHandle[0];
|
||||||
|
GLES20.glBindTexture(GLES20.GL_TEXTURE_2D, textureDatHandle[0]);
|
||||||
|
GLES20.glTexParameteri(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_MIN_FILTER, GLES20.GL_LINEAR);
|
||||||
|
GLES20.glTexParameteri(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_MAG_FILTER, GLES20.GL_LINEAR);
|
||||||
GLES20.glBindTexture(GLES20.GL_TEXTURE_2D, mTextureDataHandle);
|
GLES20.glBindTexture(GLES20.GL_TEXTURE_2D, mTextureDataHandle);
|
||||||
|
|
||||||
Bitmap bitmap1 = getBitmapFromAsset(context, "flecks.png");
|
Bitmap bitmap1 = getBitmapFromAsset(context, "flecks.png");
|
||||||
|
@ -166,6 +188,9 @@ public class Star3DIcon {
|
||||||
GLES20.glTexParameteri(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_MAG_FILTER, GLES20.GL_LINEAR);
|
GLES20.glTexParameteri(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_MAG_FILTER, GLES20.GL_LINEAR);
|
||||||
GLES20.glBindTexture(GLES20.GL_TEXTURE_2D, mBackgroundTextureHandle);
|
GLES20.glBindTexture(GLES20.GL_TEXTURE_2D, mBackgroundTextureHandle);
|
||||||
|
|
||||||
|
GLES20.glActiveTexture(GLES20.GL_TEXTURE0);
|
||||||
|
GLES20.glBindTexture(GLES20.GL_TEXTURE_2D, texture[0]);
|
||||||
|
GLES20.glUniform1i(mTextureUniformHandle, 0);
|
||||||
|
|
||||||
GLES20.glActiveTexture(GLES20.GL_TEXTURE1);
|
GLES20.glActiveTexture(GLES20.GL_TEXTURE1);
|
||||||
GLES20.glBindTexture(GLES20.GL_TEXTURE_2D, normalMap[0]);
|
GLES20.glBindTexture(GLES20.GL_TEXTURE_2D, normalMap[0]);
|
||||||
|
|
|
@ -11,6 +11,7 @@ import android.widget.FrameLayout;
|
||||||
import org.telegram.messenger.AndroidUtilities;
|
import org.telegram.messenger.AndroidUtilities;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
|
import org.telegram.ui.ActionBar.Theme;
|
||||||
import org.telegram.ui.Cells.AppIconsSelectorCell;
|
import org.telegram.ui.Cells.AppIconsSelectorCell;
|
||||||
import org.telegram.ui.Components.CubicBezierInterpolator;
|
import org.telegram.ui.Components.CubicBezierInterpolator;
|
||||||
import org.telegram.ui.Components.LayoutHelper;
|
import org.telegram.ui.Components.LayoutHelper;
|
||||||
|
@ -21,7 +22,7 @@ import java.util.List;
|
||||||
|
|
||||||
public class PremiumAppIconsPreviewView extends FrameLayout implements PagerHeaderView {
|
public class PremiumAppIconsPreviewView extends FrameLayout implements PagerHeaderView {
|
||||||
private List<LauncherIconController.LauncherIcon> icons = new ArrayList<>();
|
private List<LauncherIconController.LauncherIcon> icons = new ArrayList<>();
|
||||||
private AppIconsSelectorCell.AdaptiveIconImageView topIcon, bottomLeftIcon, bottomRightIcon;
|
private AdaptiveIconImageView topIcon, bottomLeftIcon, bottomRightIcon;
|
||||||
boolean isEmpty;
|
boolean isEmpty;
|
||||||
|
|
||||||
public PremiumAppIconsPreviewView(Context context) {
|
public PremiumAppIconsPreviewView(Context context) {
|
||||||
|
@ -42,27 +43,16 @@ public class PremiumAppIconsPreviewView extends FrameLayout implements PagerHead
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
topIcon = newIconView(context, icons.get(0));
|
topIcon = newIconView(context, 0);
|
||||||
bottomLeftIcon = newIconView(context, icons.get(1));
|
bottomLeftIcon = newIconView(context, 1);
|
||||||
bottomRightIcon = newIconView(context, icons.get(2));
|
bottomRightIcon = newIconView(context, 2);
|
||||||
|
setClipChildren(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
private AppIconsSelectorCell.AdaptiveIconImageView newIconView(Context ctx, LauncherIconController.LauncherIcon icon) {
|
private AdaptiveIconImageView newIconView(Context ctx, int i) {
|
||||||
AppIconsSelectorCell.AdaptiveIconImageView iconImageView = new AppIconsSelectorCell.AdaptiveIconImageView(ctx) {
|
LauncherIconController.LauncherIcon icon = icons.get(i);
|
||||||
private Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);
|
|
||||||
|
|
||||||
{
|
AdaptiveIconImageView iconImageView = new AdaptiveIconImageView(ctx, i);
|
||||||
paint.setColor(Color.WHITE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void draw(Canvas canvas) {
|
|
||||||
AndroidUtilities.rectTmp.set(0, 0, getWidth(), getHeight());
|
|
||||||
canvas.drawRoundRect(AndroidUtilities.rectTmp, AndroidUtilities.dp(AppIconsSelectorCell.ICONS_ROUND_RADIUS), AndroidUtilities.dp(AppIconsSelectorCell.ICONS_ROUND_RADIUS), paint);
|
|
||||||
|
|
||||||
super.draw(canvas);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
iconImageView.setLayoutParams(LayoutHelper.createFrame(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT, Gravity.CENTER, 0, 52, 0, 0));
|
iconImageView.setLayoutParams(LayoutHelper.createFrame(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT, Gravity.CENTER, 0, 52, 0, 0));
|
||||||
iconImageView.setForeground(icon.foreground);
|
iconImageView.setForeground(icon.foreground);
|
||||||
iconImageView.setBackgroundResource(icon.background);
|
iconImageView.setBackgroundResource(icon.background);
|
||||||
|
@ -108,6 +98,7 @@ public class PremiumAppIconsPreviewView extends FrameLayout implements PagerHead
|
||||||
bottomRightIcon.setScaleX(scale);
|
bottomRightIcon.setScaleX(scale);
|
||||||
bottomRightIcon.setScaleY(scale);
|
bottomRightIcon.setScaleY(scale);
|
||||||
|
|
||||||
|
|
||||||
topIcon.setTranslationY(progress * (getTop() - topIcon.getTop() - topIcon.getHeight() * 1.8f - AndroidUtilities.dp(32)));
|
topIcon.setTranslationY(progress * (getTop() - topIcon.getTop() - topIcon.getHeight() * 1.8f - AndroidUtilities.dp(32)));
|
||||||
topIcon.setTranslationX(progress * AndroidUtilities.dp(16));
|
topIcon.setTranslationX(progress * AndroidUtilities.dp(16));
|
||||||
scale = AndroidUtilities.lerp(1f, 1.8f, progress);
|
scale = AndroidUtilities.lerp(1f, 1.8f, progress);
|
||||||
|
@ -115,6 +106,7 @@ public class PremiumAppIconsPreviewView extends FrameLayout implements PagerHead
|
||||||
topIcon.setScaleX(scale);
|
topIcon.setScaleX(scale);
|
||||||
topIcon.setScaleY(scale);
|
topIcon.setScaleY(scale);
|
||||||
|
|
||||||
|
|
||||||
float leftProgress = CubicBezierInterpolator.EASE_OUT.getInterpolation(progress);
|
float leftProgress = CubicBezierInterpolator.EASE_OUT.getInterpolation(progress);
|
||||||
bottomLeftIcon.setTranslationX(leftProgress * (getLeft() - bottomLeftIcon.getLeft() - bottomLeftIcon.getWidth() * 2.5f + AndroidUtilities.dp(32)));
|
bottomLeftIcon.setTranslationX(leftProgress * (getLeft() - bottomLeftIcon.getLeft() - bottomLeftIcon.getWidth() * 2.5f + AndroidUtilities.dp(32)));
|
||||||
bottomLeftIcon.setTranslationY(leftProgress * (getBottom() - bottomLeftIcon.getBottom() + bottomLeftIcon.getHeight() * 2.5f + AndroidUtilities.dp(32)));
|
bottomLeftIcon.setTranslationY(leftProgress * (getBottom() - bottomLeftIcon.getBottom() + bottomLeftIcon.getHeight() * 2.5f + AndroidUtilities.dp(32)));
|
||||||
|
@ -122,5 +114,48 @@ public class PremiumAppIconsPreviewView extends FrameLayout implements PagerHead
|
||||||
scale = Utilities.clamp(scale, 1f, 0);
|
scale = Utilities.clamp(scale, 1f, 0);
|
||||||
bottomLeftIcon.setScaleX(scale);
|
bottomLeftIcon.setScaleX(scale);
|
||||||
bottomLeftIcon.setScaleY(scale);
|
bottomLeftIcon.setScaleY(scale);
|
||||||
|
|
||||||
|
float p = progress < 0.4f ? progress / 0.4f : 1f;
|
||||||
|
bottomRightIcon.particlesScale = p;
|
||||||
|
topIcon.particlesScale = p;
|
||||||
|
bottomLeftIcon.particlesScale = p;
|
||||||
|
}
|
||||||
|
|
||||||
|
private class AdaptiveIconImageView extends AppIconsSelectorCell.AdaptiveIconImageView {
|
||||||
|
|
||||||
|
StarParticlesView.Drawable drawable = new StarParticlesView.Drawable(20);
|
||||||
|
Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);
|
||||||
|
float particlesScale;
|
||||||
|
|
||||||
|
public AdaptiveIconImageView(Context ctx, int i) {
|
||||||
|
super(ctx);
|
||||||
|
drawable.size1 = 12;
|
||||||
|
drawable.size2 = 8;
|
||||||
|
drawable.size3 = 6;
|
||||||
|
if (i == 1) {
|
||||||
|
drawable.type = StarParticlesView.TYPE_APP_ICON_REACT;
|
||||||
|
} if (i == 0) {
|
||||||
|
drawable.type = StarParticlesView.TYPE_APP_ICON_STAR_PREMIUM;
|
||||||
|
}
|
||||||
|
drawable.colorKey = Theme.key_premiumStartSmallStarsColor2;
|
||||||
|
drawable.init();
|
||||||
|
paint.setColor(Color.WHITE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void draw(Canvas canvas) {
|
||||||
|
int outBoundOffset = AndroidUtilities.dp(10);
|
||||||
|
drawable.excludeRect.set(AndroidUtilities.dp(5), AndroidUtilities.dp(5), getMeasuredWidth() - AndroidUtilities.dp(5), getMeasuredHeight() - AndroidUtilities.dp(5));
|
||||||
|
drawable.rect.set(-outBoundOffset, -outBoundOffset, getWidth() + outBoundOffset, getHeight() + outBoundOffset);
|
||||||
|
canvas.save();
|
||||||
|
canvas.scale(1f - particlesScale, 1f - particlesScale, getMeasuredWidth() / 2f, getMeasuredHeight() / 2f);
|
||||||
|
drawable.onDraw(canvas);
|
||||||
|
canvas.restore();
|
||||||
|
invalidate();
|
||||||
|
AndroidUtilities.rectTmp.set(0, 0, getWidth(), getHeight());
|
||||||
|
canvas.drawRoundRect(AndroidUtilities.rectTmp, AndroidUtilities.dp(AppIconsSelectorCell.ICONS_ROUND_RADIUS), AndroidUtilities.dp(AppIconsSelectorCell.ICONS_ROUND_RADIUS), paint);
|
||||||
|
|
||||||
|
super.draw(canvas);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,9 +31,11 @@ import java.util.ArrayList;
|
||||||
|
|
||||||
public class StarParticlesView extends View {
|
public class StarParticlesView extends View {
|
||||||
|
|
||||||
|
|
||||||
public Drawable drawable;
|
public Drawable drawable;
|
||||||
int size;
|
int size;
|
||||||
boolean distributionAlgorithm;
|
public final static int TYPE_APP_ICON_REACT = 1001;
|
||||||
|
public static final int TYPE_APP_ICON_STAR_PREMIUM = 1002;
|
||||||
|
|
||||||
public StarParticlesView(Context context) {
|
public StarParticlesView(Context context) {
|
||||||
super(context);
|
super(context);
|
||||||
|
@ -136,6 +138,7 @@ public class StarParticlesView extends View {
|
||||||
public boolean roundEffect = true;
|
public boolean roundEffect = true;
|
||||||
public int type = -1;
|
public int type = -1;
|
||||||
public String colorKey = Theme.key_premiumStartSmallStarsColor;
|
public String colorKey = Theme.key_premiumStartSmallStarsColor;
|
||||||
|
public boolean svg;
|
||||||
|
|
||||||
public final static int TYPE_SETTINGS = 101;
|
public final static int TYPE_SETTINGS = 101;
|
||||||
|
|
||||||
|
@ -191,9 +194,9 @@ public class StarParticlesView extends View {
|
||||||
res = R.raw.premium_object_settings;
|
res = R.raw.premium_object_settings;
|
||||||
}
|
}
|
||||||
stars[i] = SvgHelper.getBitmap(res, size, size, ColorUtils.setAlphaComponent(Theme.getColor(colorKey), 30));
|
stars[i] = SvgHelper.getBitmap(res, size, size, ColorUtils.setAlphaComponent(Theme.getColor(colorKey), 30));
|
||||||
|
svg = true;
|
||||||
continue;
|
continue;
|
||||||
}
|
}else if (type == PremiumPreviewFragment.PREMIUM_FEATURE_ADS) {
|
||||||
if (type == PremiumPreviewFragment.PREMIUM_FEATURE_ADS) {
|
|
||||||
int res;
|
int res;
|
||||||
if (i == 0) {
|
if (i == 0) {
|
||||||
res = R.raw.premium_object_adsbubble;
|
res = R.raw.premium_object_adsbubble;
|
||||||
|
@ -203,9 +206,9 @@ public class StarParticlesView extends View {
|
||||||
res = R.raw.premium_object_noads;
|
res = R.raw.premium_object_noads;
|
||||||
}
|
}
|
||||||
stars[i] = SvgHelper.getBitmap(res, size, size, ColorUtils.setAlphaComponent(Theme.getColor(colorKey), 30));
|
stars[i] = SvgHelper.getBitmap(res, size, size, ColorUtils.setAlphaComponent(Theme.getColor(colorKey), 30));
|
||||||
|
svg = true;
|
||||||
continue;
|
continue;
|
||||||
}
|
} else if (type == PremiumPreviewFragment.PREMIUM_FEATURE_ANIMATED_AVATARS) {
|
||||||
if (type == PremiumPreviewFragment.PREMIUM_FEATURE_ANIMATED_AVATARS) {
|
|
||||||
int res;
|
int res;
|
||||||
if (i == 0) {
|
if (i == 0) {
|
||||||
res = R.raw.premium_object_video2;
|
res = R.raw.premium_object_video2;
|
||||||
|
@ -215,6 +218,15 @@ public class StarParticlesView extends View {
|
||||||
res = R.raw.premium_object_user;
|
res = R.raw.premium_object_user;
|
||||||
}
|
}
|
||||||
stars[i] = SvgHelper.getBitmap(res, size, size, ColorUtils.setAlphaComponent(Theme.getColor(colorKey), 30));
|
stars[i] = SvgHelper.getBitmap(res, size, size, ColorUtils.setAlphaComponent(Theme.getColor(colorKey), 30));
|
||||||
|
svg = true;
|
||||||
|
continue;
|
||||||
|
} else if (type == TYPE_APP_ICON_REACT) {
|
||||||
|
stars[i] = SvgHelper.getBitmap(R.raw.premium_object_fire, size, size, ColorUtils.setAlphaComponent(Theme.getColor(colorKey), 30));
|
||||||
|
svg = true;
|
||||||
|
continue;
|
||||||
|
} else if (type == TYPE_APP_ICON_STAR_PREMIUM) {
|
||||||
|
stars[i] = SvgHelper.getBitmap(R.raw.premium_object_star2, size, size, ColorUtils.setAlphaComponent(Theme.getColor(colorKey), 30));
|
||||||
|
svg = true;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -255,7 +267,11 @@ public class StarParticlesView extends View {
|
||||||
if (roundEffect) {
|
if (roundEffect) {
|
||||||
paint1.setPathEffect(new CornerPathEffect(AndroidUtilities.dpf2(size1 / 5f)));
|
paint1.setPathEffect(new CornerPathEffect(AndroidUtilities.dpf2(size1 / 5f)));
|
||||||
}
|
}
|
||||||
paint1.setAlpha(120);
|
if (useBlur) {
|
||||||
|
paint1.setAlpha(60);
|
||||||
|
} else {
|
||||||
|
paint1.setAlpha(120);
|
||||||
|
}
|
||||||
canvas.drawPath(path, paint1);
|
canvas.drawPath(path, paint1);
|
||||||
paint1.setPathEffect(null);
|
paint1.setPathEffect(null);
|
||||||
paint1.setAlpha(255);
|
paint1.setAlpha(255);
|
||||||
|
@ -475,7 +491,7 @@ public class StarParticlesView extends View {
|
||||||
double a = Math.atan2(x - rect.centerX(), y - rect.centerY());
|
double a = Math.atan2(x - rect.centerX(), y - rect.centerY());
|
||||||
vecX = (float) Math.sin(a);
|
vecX = (float) Math.sin(a);
|
||||||
vecY = (float) Math.cos(a);
|
vecY = (float) Math.cos(a);
|
||||||
if (type == PremiumPreviewFragment.PREMIUM_FEATURE_ADVANCED_CHAT_MANAGEMENT || type == PremiumPreviewFragment.PREMIUM_FEATURE_ADS || type == PremiumPreviewFragment.PREMIUM_FEATURE_ANIMATED_AVATARS) {
|
if (svg) {
|
||||||
alpha = (int) (120 * ((50 + Utilities.fastRandom.nextInt(50)) / 100f));
|
alpha = (int) (120 * ((50 + Utilities.fastRandom.nextInt(50)) / 100f));
|
||||||
} else {
|
} else {
|
||||||
alpha = (int) (255 * ((50 + Utilities.fastRandom.nextInt(50)) / 100f));
|
alpha = (int) (255 * ((50 + Utilities.fastRandom.nextInt(50)) / 100f));
|
||||||
|
|
|
@ -452,17 +452,21 @@ public class ProfileGalleryView extends CircularViewPager implements Notificatio
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean initIfEmpty(ImageLocation imageLocation, ImageLocation thumbLocation) {
|
public boolean initIfEmpty(ImageLocation imageLocation, ImageLocation thumbLocation, boolean reload) {
|
||||||
if (imageLocation == null || thumbLocation == null || settingMainPhoto != 0) {
|
if (imageLocation == null || thumbLocation == null || settingMainPhoto != 0) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (prevImageLocation == null || prevImageLocation.location.local_id != imageLocation.location.local_id) {
|
if (prevImageLocation == null || prevImageLocation.location.local_id != imageLocation.location.local_id) {
|
||||||
if (!imagesLocations.isEmpty()) {
|
if (!imagesLocations.isEmpty()) {
|
||||||
prevImageLocation = imageLocation;
|
prevImageLocation = imageLocation;
|
||||||
MessagesController.getInstance(currentAccount).loadDialogPhotos(dialogId, 80, 0, true, parentClassGuid);
|
if (reload) {
|
||||||
|
MessagesController.getInstance(currentAccount).loadDialogPhotos(dialogId, 80, 0, true, parentClassGuid);
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
MessagesController.getInstance(currentAccount).loadDialogPhotos(dialogId, 80, 0, true, parentClassGuid);
|
if (reload) {
|
||||||
|
MessagesController.getInstance(currentAccount).loadDialogPhotos(dialogId, 80, 0, true, parentClassGuid);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!imagesLocations.isEmpty()) {
|
if (!imagesLocations.isEmpty()) {
|
||||||
|
|
|
@ -120,7 +120,8 @@ public class RLottieDrawable extends BitmapDrawable implements Animatable {
|
||||||
private static ThreadLocal<byte[]> bufferLocal = new ThreadLocal<>();
|
private static ThreadLocal<byte[]> bufferLocal = new ThreadLocal<>();
|
||||||
|
|
||||||
private ArrayList<WeakReference<View>> parentViews = new ArrayList<>();
|
private ArrayList<WeakReference<View>> parentViews = new ArrayList<>();
|
||||||
private static DispatchQueuePool loadFrameRunnableQueue = new DispatchQueuePool(4);
|
private static final DispatchQueuePool loadFrameRunnableQueue = new DispatchQueuePool(2);
|
||||||
|
private static final DispatchQueuePool largeSizeLoadFrameRunnableQueue = new DispatchQueuePool(4);
|
||||||
private static ThreadPoolExecutor lottieCacheGenerateQueue;
|
private static ThreadPoolExecutor lottieCacheGenerateQueue;
|
||||||
private static HashSet<String> generatingCacheFiles = new HashSet<>();
|
private static HashSet<String> generatingCacheFiles = new HashSet<>();
|
||||||
|
|
||||||
|
@ -131,6 +132,8 @@ public class RLottieDrawable extends BitmapDrawable implements Animatable {
|
||||||
private Runnable onAnimationEndListener;
|
private Runnable onAnimationEndListener;
|
||||||
private Runnable onFrameReadyRunnable;
|
private Runnable onFrameReadyRunnable;
|
||||||
|
|
||||||
|
private DispatchQueuePool loadFrameQueue = loadFrameRunnableQueue;
|
||||||
|
|
||||||
protected Runnable uiRunnableNoFrame = new Runnable() {
|
protected Runnable uiRunnableNoFrame = new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
|
@ -392,6 +395,11 @@ public class RLottieDrawable extends BitmapDrawable implements Animatable {
|
||||||
if (precache && lottieCacheGenerateQueue == null) {
|
if (precache && lottieCacheGenerateQueue == null) {
|
||||||
lottieCacheGenerateQueue = new ThreadPoolExecutor(1, 1, 0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue<>());
|
lottieCacheGenerateQueue = new ThreadPoolExecutor(1, 1, 0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue<>());
|
||||||
}
|
}
|
||||||
|
if (w > AndroidUtilities.dp(120) || h > AndroidUtilities.dp(120)) {
|
||||||
|
loadFrameQueue = largeSizeLoadFrameRunnableQueue;
|
||||||
|
} else {
|
||||||
|
loadFrameQueue = loadFrameRunnableQueue;
|
||||||
|
}
|
||||||
if (nativePtr == 0) {
|
if (nativePtr == 0) {
|
||||||
file.delete();
|
file.delete();
|
||||||
}
|
}
|
||||||
|
@ -422,6 +430,11 @@ public class RLottieDrawable extends BitmapDrawable implements Animatable {
|
||||||
shouldLimitFps = false;
|
shouldLimitFps = false;
|
||||||
}
|
}
|
||||||
timeBetweenFrames = Math.max(shouldLimitFps ? 33 : 16, (int) (1000.0f / metaData[1]));
|
timeBetweenFrames = Math.max(shouldLimitFps ? 33 : 16, (int) (1000.0f / metaData[1]));
|
||||||
|
if (w > AndroidUtilities.dp(100) || w > AndroidUtilities.dp(100)) {
|
||||||
|
loadFrameQueue = largeSizeLoadFrameRunnableQueue;
|
||||||
|
} else {
|
||||||
|
loadFrameQueue = loadFrameRunnableQueue;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public RLottieDrawable(int rawRes, String name, int w, int h) {
|
public RLottieDrawable(int rawRes, String name, int w, int h) {
|
||||||
|
@ -826,7 +839,7 @@ public class RLottieDrawable extends BitmapDrawable implements Animatable {
|
||||||
pendingReplaceColors = newReplaceColors;
|
pendingReplaceColors = newReplaceColors;
|
||||||
newReplaceColors = null;
|
newReplaceColors = null;
|
||||||
}
|
}
|
||||||
loadFrameRunnableQueue.execute(loadFrameTask = loadFrameRunnable);
|
loadFrameQueue.execute(loadFrameTask = loadFrameRunnable);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package org.telegram.ui.Components;
|
package org.telegram.ui.Components;
|
||||||
|
|
||||||
import android.graphics.Canvas;
|
import android.graphics.Canvas;
|
||||||
|
import android.graphics.Color;
|
||||||
import android.graphics.ColorFilter;
|
import android.graphics.ColorFilter;
|
||||||
import android.graphics.Paint;
|
import android.graphics.Paint;
|
||||||
import android.graphics.PixelFormat;
|
import android.graphics.PixelFormat;
|
||||||
|
@ -20,6 +21,8 @@ public class ScamDrawable extends Drawable {
|
||||||
private int textWidth;
|
private int textWidth;
|
||||||
private String text;
|
private String text;
|
||||||
private int currentType;
|
private int currentType;
|
||||||
|
int colorAlpha = 255;
|
||||||
|
int alpha = 255;
|
||||||
|
|
||||||
public ScamDrawable(int textSize, int type) {
|
public ScamDrawable(int textSize, int type) {
|
||||||
super();
|
super();
|
||||||
|
@ -54,11 +57,16 @@ public class ScamDrawable extends Drawable {
|
||||||
public void setColor(int color) {
|
public void setColor(int color) {
|
||||||
textPaint.setColor(color);
|
textPaint.setColor(color);
|
||||||
paint.setColor(color);
|
paint.setColor(color);
|
||||||
|
colorAlpha = Color.alpha(color);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setAlpha(int alpha) {
|
public void setAlpha(int alpha) {
|
||||||
|
if (this.alpha != alpha) {
|
||||||
|
int localAlpha = (int) (colorAlpha * (alpha / 255f));
|
||||||
|
paint.setAlpha(localAlpha);
|
||||||
|
textPaint.setAlpha(localAlpha);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -558,6 +558,7 @@ public class SharedMediaLayout extends FrameLayout implements NotificationCenter
|
||||||
notificationCenter.addObserver(this, NotificationCenter.messagesDeleted);
|
notificationCenter.addObserver(this, NotificationCenter.messagesDeleted);
|
||||||
notificationCenter.addObserver(this, NotificationCenter.replaceMessagesObjects);
|
notificationCenter.addObserver(this, NotificationCenter.replaceMessagesObjects);
|
||||||
notificationCenter.addObserver(this, NotificationCenter.chatInfoDidLoad);
|
notificationCenter.addObserver(this, NotificationCenter.chatInfoDidLoad);
|
||||||
|
notificationCenter.addObserver(this, NotificationCenter.fileLoaded);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addDelegate(SharedMediaPreloaderDelegate delegate) {
|
public void addDelegate(SharedMediaPreloaderDelegate delegate) {
|
||||||
|
@ -582,6 +583,7 @@ public class SharedMediaLayout extends FrameLayout implements NotificationCenter
|
||||||
notificationCenter.removeObserver(this, NotificationCenter.messagesDeleted);
|
notificationCenter.removeObserver(this, NotificationCenter.messagesDeleted);
|
||||||
notificationCenter.removeObserver(this, NotificationCenter.replaceMessagesObjects);
|
notificationCenter.removeObserver(this, NotificationCenter.replaceMessagesObjects);
|
||||||
notificationCenter.removeObserver(this, NotificationCenter.chatInfoDidLoad);
|
notificationCenter.removeObserver(this, NotificationCenter.chatInfoDidLoad);
|
||||||
|
notificationCenter.removeObserver(this, NotificationCenter.fileLoaded);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int[] getLastMediaCount() {
|
public int[] getLastMediaCount() {
|
||||||
|
@ -815,6 +817,17 @@ public class SharedMediaLayout extends FrameLayout implements NotificationCenter
|
||||||
if (dialogId < 0 && chatFull.id == -dialogId) {
|
if (dialogId < 0 && chatFull.id == -dialogId) {
|
||||||
setChatInfo(chatFull);
|
setChatInfo(chatFull);
|
||||||
}
|
}
|
||||||
|
} else if (id == NotificationCenter.fileLoaded) {
|
||||||
|
ArrayList<MessageObject> allMessages = new ArrayList<>();
|
||||||
|
for (int i = 0 ; i < sharedMediaData.length; i++) {
|
||||||
|
allMessages.addAll(sharedMediaData[i].messages);
|
||||||
|
}
|
||||||
|
Utilities.globalQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
FileLoader.getInstance(account).checkMediaExistance(allMessages);
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2741,6 +2754,7 @@ public class SharedMediaLayout extends FrameLayout implements NotificationCenter
|
||||||
sharedMediaData[type].totalCount = mediaData[type].totalCount;
|
sharedMediaData[type].totalCount = mediaData[type].totalCount;
|
||||||
}
|
}
|
||||||
sharedMediaData[type].messages.addAll(mediaData[type].messages);
|
sharedMediaData[type].messages.addAll(mediaData[type].messages);
|
||||||
|
|
||||||
sharedMediaData[type].sections.addAll(mediaData[type].sections);
|
sharedMediaData[type].sections.addAll(mediaData[type].sections);
|
||||||
for (HashMap.Entry<String, ArrayList<MessageObject>> entry : mediaData[type].sectionArrays.entrySet()) {
|
for (HashMap.Entry<String, ArrayList<MessageObject>> entry : mediaData[type].sectionArrays.entrySet()) {
|
||||||
sharedMediaData[type].sectionArrays.put(entry.getKey(), new ArrayList<>(entry.getValue()));
|
sharedMediaData[type].sectionArrays.put(entry.getKey(), new ArrayList<>(entry.getValue()));
|
||||||
|
|
|
@ -22,6 +22,7 @@ import org.telegram.messenger.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.SharedConfig;
|
import org.telegram.messenger.SharedConfig;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.tgnet.ConnectionsManager;
|
import org.telegram.tgnet.ConnectionsManager;
|
||||||
import org.telegram.tgnet.TLRPC;
|
import org.telegram.tgnet.TLRPC;
|
||||||
import org.telegram.ui.Cells.ChatMessageCell;
|
import org.telegram.ui.Cells.ChatMessageCell;
|
||||||
|
@ -219,6 +220,7 @@ public class EmojiAnimationsOverlay implements NotificationCenter.NotificationCe
|
||||||
for (int i = 0; i < drawingObjects.size(); i++) {
|
for (int i = 0; i < drawingObjects.size(); i++) {
|
||||||
DrawingObject drawingObject = drawingObjects.get(i);
|
DrawingObject drawingObject = drawingObjects.get(i);
|
||||||
drawingObject.viewFound = false;
|
drawingObject.viewFound = false;
|
||||||
|
float childY = 0;
|
||||||
for (int k = 0; k < listView.getChildCount(); k++) {
|
for (int k = 0; k < listView.getChildCount(); k++) {
|
||||||
View child = listView.getChildAt(k);
|
View child = listView.getChildAt(k);
|
||||||
if (child instanceof ChatMessageCell) {
|
if (child instanceof ChatMessageCell) {
|
||||||
|
@ -227,10 +229,10 @@ public class EmojiAnimationsOverlay implements NotificationCenter.NotificationCe
|
||||||
drawingObject.viewFound = true;
|
drawingObject.viewFound = true;
|
||||||
float viewX = listView.getX() + child.getX();
|
float viewX = listView.getX() + child.getX();
|
||||||
float viewY = listView.getY() + child.getY();
|
float viewY = listView.getY() + child.getY();
|
||||||
|
childY = child.getY();
|
||||||
if (drawingObject.isPremiumSticker) {
|
if (drawingObject.isPremiumSticker) {
|
||||||
drawingObject.lastX = viewX + cell.getPhotoImage().getImageX();
|
drawingObject.lastX = viewX + cell.getPhotoImage().getImageX();
|
||||||
drawingObject.lastY = viewY + cell.getPhotoImage().getImageY();
|
drawingObject.lastY = viewY + cell.getPhotoImage().getImageY();
|
||||||
;
|
|
||||||
} else {
|
} else {
|
||||||
viewX += cell.getPhotoImage().getImageX();
|
viewX += cell.getPhotoImage().getImageX();
|
||||||
viewY += cell.getPhotoImage().getImageY();
|
viewY += cell.getPhotoImage().getImageY();
|
||||||
|
@ -250,6 +252,16 @@ public class EmojiAnimationsOverlay implements NotificationCenter.NotificationCe
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!drawingObject.viewFound || childY + drawingObject.lastH < chatActivity.getChatListViewPadding() || childY > listView.getMeasuredHeight() - chatActivity.blurredViewBottomOffset) {
|
||||||
|
drawingObject.removing = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (drawingObject.removing && drawingObject.removeProgress != 1f) {
|
||||||
|
drawingObject.removeProgress = Utilities.clamp(drawingObject.removeProgress + 16 / 150f, 1f, 0);
|
||||||
|
drawingObject.imageReceiver.setAlpha(1f - drawingObject.removeProgress);
|
||||||
|
chatActivity.contentView.invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
if (drawingObject.isPremiumSticker) {
|
if (drawingObject.isPremiumSticker) {
|
||||||
float size = drawingObject.lastH * 1.49926f;
|
float size = drawingObject.lastH * 1.49926f;
|
||||||
float paddingHorizontal = size * 0.0546875f;
|
float paddingHorizontal = size * 0.0546875f;
|
||||||
|
@ -279,7 +291,7 @@ public class EmojiAnimationsOverlay implements NotificationCenter.NotificationCe
|
||||||
drawingObject.imageReceiver.draw(canvas);
|
drawingObject.imageReceiver.draw(canvas);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (drawingObject.wasPlayed && drawingObject.imageReceiver.getLottieAnimation() != null && drawingObject.imageReceiver.getLottieAnimation().getCurrentFrame() == drawingObject.imageReceiver.getLottieAnimation().getFramesCount() - 2) {
|
if (drawingObject.removeProgress == 1f || (drawingObject.wasPlayed && drawingObject.imageReceiver.getLottieAnimation() != null && drawingObject.imageReceiver.getLottieAnimation().getCurrentFrame() == drawingObject.imageReceiver.getLottieAnimation().getFramesCount() - 2)) {
|
||||||
drawingObjects.remove(i);
|
drawingObjects.remove(i);
|
||||||
i--;
|
i--;
|
||||||
} else if (drawingObject.imageReceiver.getLottieAnimation() != null && drawingObject.imageReceiver.getLottieAnimation().isRunning()) {
|
} else if (drawingObject.imageReceiver.getLottieAnimation() != null && drawingObject.imageReceiver.getLottieAnimation().isRunning()) {
|
||||||
|
@ -627,6 +639,8 @@ public class EmojiAnimationsOverlay implements NotificationCenter.NotificationCe
|
||||||
public boolean isPremiumSticker;
|
public boolean isPremiumSticker;
|
||||||
boolean wasPlayed;
|
boolean wasPlayed;
|
||||||
boolean isOut;
|
boolean isOut;
|
||||||
|
boolean removing;
|
||||||
|
float removeProgress;
|
||||||
int messageId;
|
int messageId;
|
||||||
TLRPC.Document document;
|
TLRPC.Document document;
|
||||||
ImageReceiver imageReceiver = new ImageReceiver();
|
ImageReceiver imageReceiver = new ImageReceiver();
|
||||||
|
|
|
@ -7443,7 +7443,7 @@ public class GroupCallActivity extends BottomSheet implements NotificationCenter
|
||||||
avatarsViewPager.setHasActiveVideo(hasAttachedRenderer);
|
avatarsViewPager.setHasActiveVideo(hasAttachedRenderer);
|
||||||
avatarsViewPager.setData(peerId, true);
|
avatarsViewPager.setData(peerId, true);
|
||||||
avatarsViewPager.setCreateThumbFromParent(true);
|
avatarsViewPager.setCreateThumbFromParent(true);
|
||||||
avatarsViewPager.initIfEmpty(imageLocation, thumbLocation);
|
avatarsViewPager.initIfEmpty(imageLocation, thumbLocation, true);
|
||||||
if (scrimRenderer != null) {
|
if (scrimRenderer != null) {
|
||||||
scrimRenderer.setShowingAsScrimView(true, true);
|
scrimRenderer.setShowingAsScrimView(true, true);
|
||||||
}
|
}
|
||||||
|
@ -8428,7 +8428,7 @@ public class GroupCallActivity extends BottomSheet implements NotificationCenter
|
||||||
thumb = thumbLocation;
|
thumb = thumbLocation;
|
||||||
}
|
}
|
||||||
avatarsViewPager.setCreateThumbFromParent(false);
|
avatarsViewPager.setCreateThumbFromParent(false);
|
||||||
avatarsViewPager.initIfEmpty(imageLocation, thumb);
|
avatarsViewPager.initIfEmpty(imageLocation, thumb, true);
|
||||||
avatar = null;
|
avatar = null;
|
||||||
avatarBig = null;
|
avatarBig = null;
|
||||||
AndroidUtilities.updateVisibleRows(listView);
|
AndroidUtilities.updateVisibleRows(listView);
|
||||||
|
@ -8456,7 +8456,7 @@ public class GroupCallActivity extends BottomSheet implements NotificationCenter
|
||||||
thumb = thumbLocation;
|
thumb = thumbLocation;
|
||||||
}
|
}
|
||||||
avatarsViewPager.setCreateThumbFromParent(false);
|
avatarsViewPager.setCreateThumbFromParent(false);
|
||||||
avatarsViewPager.initIfEmpty(imageLocation, thumb);
|
avatarsViewPager.initIfEmpty(imageLocation, thumb, true);
|
||||||
avatar = null;
|
avatar = null;
|
||||||
avatarBig = null;
|
avatarBig = null;
|
||||||
AndroidUtilities.updateVisibleRows(listView);
|
AndroidUtilities.updateVisibleRows(listView);
|
||||||
|
|
|
@ -68,6 +68,7 @@ import android.transition.TransitionManager;
|
||||||
import android.transition.TransitionSet;
|
import android.transition.TransitionSet;
|
||||||
import android.transition.TransitionValues;
|
import android.transition.TransitionValues;
|
||||||
import android.util.FloatProperty;
|
import android.util.FloatProperty;
|
||||||
|
import android.util.Log;
|
||||||
import android.util.Property;
|
import android.util.Property;
|
||||||
import android.util.Range;
|
import android.util.Range;
|
||||||
import android.util.SparseArray;
|
import android.util.SparseArray;
|
||||||
|
@ -11984,13 +11985,22 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
||||||
if (!exists && f1Final != null) {
|
if (!exists && f1Final != null) {
|
||||||
exists = f1Final.exists();
|
exists = f1Final.exists();
|
||||||
}
|
}
|
||||||
|
|
||||||
File f2Local = f2Final;
|
File f2Local = f2Final;
|
||||||
|
File f3Local = null;
|
||||||
if (f2Local == null && finalF2Resolver != null) {
|
if (f2Local == null && finalF2Resolver != null) {
|
||||||
f2Local = finalF2Resolver.getFile();
|
f2Local = finalF2Resolver.getFile();
|
||||||
|
} else if (finalF2Resolver != null) {
|
||||||
|
f3Local = finalF2Resolver.getFile();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!exists && f2Local != null) {
|
if (!exists && f2Local != null) {
|
||||||
exists = f2Local.exists();
|
exists = f2Local.exists();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!exists && f3Local != null) {
|
||||||
|
exists = f3Local.exists();
|
||||||
|
}
|
||||||
if (!exists && a != 0 && messageObjectFinal != null && canStreamFinal) {
|
if (!exists && a != 0 && messageObjectFinal != null && canStreamFinal) {
|
||||||
if (DownloadController.getInstance(currentAccount).canDownloadMedia(messageObjectFinal.messageOwner) != 0) {
|
if (DownloadController.getInstance(currentAccount).canDownloadMedia(messageObjectFinal.messageOwner) != 0) {
|
||||||
if ((parentChatActivity == null || parentChatActivity.getCurrentEncryptedChat() == null) && !messageObjectFinal.shouldEncryptPhotoOrVideo()) {
|
if ((parentChatActivity == null || parentChatActivity.getCurrentEncryptedChat() == null) && !messageObjectFinal.shouldEncryptPhotoOrVideo()) {
|
||||||
|
|
|
@ -47,7 +47,6 @@ import android.text.Spanned;
|
||||||
import android.text.TextPaint;
|
import android.text.TextPaint;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.text.style.ForegroundColorSpan;
|
import android.text.style.ForegroundColorSpan;
|
||||||
import android.text.util.Linkify;
|
|
||||||
import android.util.Property;
|
import android.util.Property;
|
||||||
import android.util.SparseIntArray;
|
import android.util.SparseIntArray;
|
||||||
import android.util.TypedValue;
|
import android.util.TypedValue;
|
||||||
|
@ -1020,7 +1019,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onPhotosLoaded() {
|
public void onPhotosLoaded() {
|
||||||
updateProfileData();
|
updateProfileData(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1920,7 +1919,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
userConfig.setCurrentUser(user);
|
userConfig.setCurrentUser(user);
|
||||||
userConfig.saveConfig(true);
|
userConfig.saveConfig(true);
|
||||||
NotificationCenter.getInstance(currentAccount).postNotificationName(NotificationCenter.mainUserInfoChanged);
|
NotificationCenter.getInstance(currentAccount).postNotificationName(NotificationCenter.mainUserInfoChanged);
|
||||||
updateProfileData();
|
updateProfileData(true);
|
||||||
}
|
}
|
||||||
avatarsViewPager.commitMoveToBegin();
|
avatarsViewPager.commitMoveToBegin();
|
||||||
} else if (id == edit_avatar) {
|
} else if (id == edit_avatar) {
|
||||||
|
@ -3393,7 +3392,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
};
|
};
|
||||||
mediaCounterTextView.setAlpha(0.0f);
|
mediaCounterTextView.setAlpha(0.0f);
|
||||||
avatarContainer2.addView(mediaCounterTextView, LayoutHelper.createFrame(LayoutHelper.WRAP_CONTENT, LayoutHelper.WRAP_CONTENT, Gravity.LEFT | Gravity.TOP, 118, 0, 8, 0));
|
avatarContainer2.addView(mediaCounterTextView, LayoutHelper.createFrame(LayoutHelper.WRAP_CONTENT, LayoutHelper.WRAP_CONTENT, Gravity.LEFT | Gravity.TOP, 118, 0, 8, 0));
|
||||||
updateProfileData();
|
updateProfileData(true);
|
||||||
|
|
||||||
writeButton = new RLottieImageView(context);
|
writeButton = new RLottieImageView(context);
|
||||||
|
|
||||||
|
@ -5062,7 +5061,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
boolean infoChanged = (mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0;
|
boolean infoChanged = (mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0;
|
||||||
if (userId != 0) {
|
if (userId != 0) {
|
||||||
if (infoChanged) {
|
if (infoChanged) {
|
||||||
updateProfileData();
|
updateProfileData(true);
|
||||||
}
|
}
|
||||||
if ((mask & MessagesController.UPDATE_MASK_PHONE) != 0) {
|
if ((mask & MessagesController.UPDATE_MASK_PHONE) != 0) {
|
||||||
if (listView != null) {
|
if (listView != null) {
|
||||||
|
@ -5079,7 +5078,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
} else {
|
} else {
|
||||||
updateOnlineCount(true);
|
updateOnlineCount(true);
|
||||||
}
|
}
|
||||||
updateProfileData();
|
updateProfileData(true);
|
||||||
}
|
}
|
||||||
if (infoChanged) {
|
if (infoChanged) {
|
||||||
if (listView != null) {
|
if (listView != null) {
|
||||||
|
@ -5100,7 +5099,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
}
|
}
|
||||||
chatInfo.online_count = (Integer) args[1];
|
chatInfo.online_count = (Integer) args[1];
|
||||||
updateOnlineCount(true);
|
updateOnlineCount(true);
|
||||||
updateProfileData();
|
updateProfileData(false);
|
||||||
} else if (id == NotificationCenter.contactsDidLoad) {
|
} else if (id == NotificationCenter.contactsDidLoad) {
|
||||||
createActionBarMenu(true);
|
createActionBarMenu(true);
|
||||||
} else if (id == NotificationCenter.encryptedChatCreated) {
|
} else if (id == NotificationCenter.encryptedChatCreated) {
|
||||||
|
@ -5328,7 +5327,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
setParentActivityTitle(LocaleController.getString("Settings", R.string.Settings));
|
setParentActivityTitle(LocaleController.getString("Settings", R.string.Settings));
|
||||||
}
|
}
|
||||||
|
|
||||||
updateProfileData();
|
updateProfileData(true);
|
||||||
fixLayout();
|
fixLayout();
|
||||||
if (nameTextView[1] != null) {
|
if (nameTextView[1] != null) {
|
||||||
setParentActivityTitle(nameTextView[1].getText());
|
setParentActivityTitle(nameTextView[1].getText());
|
||||||
|
@ -5524,7 +5523,9 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
topView.invalidate();
|
topView.invalidate();
|
||||||
|
|
||||||
needLayout(true);
|
needLayout(true);
|
||||||
fragmentView.invalidate();
|
if (fragmentView != null) {
|
||||||
|
fragmentView.invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
if (aboutLinkCell != null) {
|
if (aboutLinkCell != null) {
|
||||||
aboutLinkCell.invalidate();
|
aboutLinkCell.invalidate();
|
||||||
|
@ -6234,7 +6235,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
return premuimCrossfadeDrawable;
|
return premuimCrossfadeDrawable;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateProfileData() {
|
private void updateProfileData(boolean reload) {
|
||||||
if (avatarContainer == null || nameTextView == null) {
|
if (avatarContainer == null || nameTextView == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -6267,7 +6268,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
final ImageLocation thumbLocation = ImageLocation.getForUserOrChat(user, ImageLocation.TYPE_SMALL);
|
final ImageLocation thumbLocation = ImageLocation.getForUserOrChat(user, ImageLocation.TYPE_SMALL);
|
||||||
final ImageLocation videoThumbLocation = ImageLocation.getForUserOrChat(user, ImageLocation.TYPE_VIDEO_THUMB);
|
final ImageLocation videoThumbLocation = ImageLocation.getForUserOrChat(user, ImageLocation.TYPE_VIDEO_THUMB);
|
||||||
final ImageLocation videoLocation = avatarsViewPager.getCurrentVideoLocation(thumbLocation, imageLocation);
|
final ImageLocation videoLocation = avatarsViewPager.getCurrentVideoLocation(thumbLocation, imageLocation);
|
||||||
avatarsViewPager.initIfEmpty(imageLocation, thumbLocation);
|
avatarsViewPager.initIfEmpty(imageLocation, thumbLocation, reload);
|
||||||
if (avatarBig == null) {
|
if (avatarBig == null) {
|
||||||
if (videoThumbLocation != null) {
|
if (videoThumbLocation != null) {
|
||||||
avatarImage.getImageReceiver().setVideoThumbIsSame(true);
|
avatarImage.getImageReceiver().setVideoThumbIsSame(true);
|
||||||
|
@ -6526,7 +6527,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
final ImageLocation imageLocation = ImageLocation.getForUserOrChat(chat, ImageLocation.TYPE_BIG);
|
final ImageLocation imageLocation = ImageLocation.getForUserOrChat(chat, ImageLocation.TYPE_BIG);
|
||||||
final ImageLocation thumbLocation = ImageLocation.getForUserOrChat(chat, ImageLocation.TYPE_SMALL);
|
final ImageLocation thumbLocation = ImageLocation.getForUserOrChat(chat, ImageLocation.TYPE_SMALL);
|
||||||
final ImageLocation videoLocation = avatarsViewPager.getCurrentVideoLocation(thumbLocation, imageLocation);
|
final ImageLocation videoLocation = avatarsViewPager.getCurrentVideoLocation(thumbLocation, imageLocation);
|
||||||
boolean initied = avatarsViewPager.initIfEmpty(imageLocation, thumbLocation);
|
boolean initied = avatarsViewPager.initIfEmpty(imageLocation, thumbLocation, reload);
|
||||||
if ((imageLocation == null || initied) && isPulledDown) {
|
if ((imageLocation == null || initied) && isPulledDown) {
|
||||||
final View view = layoutManager.findViewByPosition(0);
|
final View view = layoutManager.findViewByPosition(0);
|
||||||
if (view != null) {
|
if (view != null) {
|
||||||
|
@ -7160,7 +7161,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
avatar = null;
|
avatar = null;
|
||||||
avatarBig = null;
|
avatarBig = null;
|
||||||
avatarsViewPager.setCreateThumbFromParent(false);
|
avatarsViewPager.setCreateThumbFromParent(false);
|
||||||
updateProfileData();
|
updateProfileData(true);
|
||||||
showAvatarProgress(false, true);
|
showAvatarProgress(false, true);
|
||||||
getNotificationCenter().postNotificationName(NotificationCenter.updateInterfaces, MessagesController.UPDATE_MASK_ALL);
|
getNotificationCenter().postNotificationName(NotificationCenter.updateInterfaces, MessagesController.UPDATE_MASK_ALL);
|
||||||
getNotificationCenter().postNotificationName(NotificationCenter.mainUserInfoChanged);
|
getNotificationCenter().postNotificationName(NotificationCenter.mainUserInfoChanged);
|
||||||
|
|
Loading…
Reference in a new issue