New photo viewer(close by swipe down, not tested on 2.x), optimize emoji load, fixed audio notes and typing in secret chats
https://github.com/DrKLO/Telegram/pull/443
@ -3,7 +3,7 @@ buildscript {
|
|||||||
mavenCentral()
|
mavenCentral()
|
||||||
}
|
}
|
||||||
dependencies {
|
dependencies {
|
||||||
classpath 'com.android.tools.build:gradle:0.10.+'
|
classpath 'com.android.tools.build:gradle:0.11.+'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
apply plugin: 'android'
|
apply plugin: 'android'
|
||||||
@ -18,7 +18,6 @@ tasks.withType(JavaCompile) {
|
|||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
compile 'com.android.support:support-v4:19.0.+'
|
compile 'com.android.support:support-v4:19.0.+'
|
||||||
compile 'com.android.support:appcompat-v7:19.0.+'
|
|
||||||
compile 'com.google.android.gms:play-services:4.1.+'
|
compile 'com.google.android.gms:play-services:4.1.+'
|
||||||
compile 'net.hockeyapp.android:HockeySDK:3.0.1'
|
compile 'net.hockeyapp.android:HockeySDK:3.0.1'
|
||||||
}
|
}
|
||||||
@ -82,7 +81,7 @@ android {
|
|||||||
defaultConfig {
|
defaultConfig {
|
||||||
minSdkVersion 8
|
minSdkVersion 8
|
||||||
targetSdkVersion 19
|
targetSdkVersion 19
|
||||||
versionCode 240
|
versionCode 243
|
||||||
versionName "1.4.15"
|
versionName "1.4.15"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -100,11 +100,6 @@
|
|||||||
android:configChanges="keyboard|keyboardHidden|orientation|screenSize"
|
android:configChanges="keyboard|keyboardHidden|orientation|screenSize"
|
||||||
android:screenOrientation="portrait">
|
android:screenOrientation="portrait">
|
||||||
</activity>
|
</activity>
|
||||||
<activity
|
|
||||||
android:name="org.telegram.ui.GalleryImageViewer"
|
|
||||||
android:theme="@style/Theme.TMessages.Gallery"
|
|
||||||
android:configChanges="keyboard|keyboardHidden|orientation|screenSize">
|
|
||||||
</activity>
|
|
||||||
|
|
||||||
<receiver android:name="org.telegram.messenger.SmsListener">
|
<receiver android:name="org.telegram.messenger.SmsListener">
|
||||||
<intent-filter>
|
<intent-filter>
|
||||||
|
Before Width: | Height: | Size: 626 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji2.0x_0.jpg
Normal file
After Width: | Height: | Size: 135 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji2.0x_1.jpg
Normal file
After Width: | Height: | Size: 76 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji2.0x_2.jpg
Normal file
After Width: | Height: | Size: 151 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji2.0x_3.jpg
Normal file
After Width: | Height: | Size: 80 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji2.0x_4.jpg
Normal file
After Width: | Height: | Size: 136 KiB |
Before Width: | Height: | Size: 283 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji2.0x_a_0.jpg
Normal file
After Width: | Height: | Size: 58 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji2.0x_a_1.jpg
Normal file
After Width: | Height: | Size: 40 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji2.0x_a_2.jpg
Normal file
After Width: | Height: | Size: 73 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji2.0x_a_3.jpg
Normal file
After Width: | Height: | Size: 29 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji2.0x_a_4.jpg
Normal file
After Width: | Height: | Size: 58 KiB |
Before Width: | Height: | Size: 1.1 MiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji3.0x_0.jpg
Normal file
After Width: | Height: | Size: 237 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji3.0x_1.jpg
Normal file
After Width: | Height: | Size: 132 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji3.0x_2.jpg
Normal file
After Width: | Height: | Size: 270 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji3.0x_3.jpg
Normal file
After Width: | Height: | Size: 144 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji3.0x_4.jpg
Normal file
After Width: | Height: | Size: 249 KiB |
Before Width: | Height: | Size: 481 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji3.0x_a_0.jpg
Normal file
After Width: | Height: | Size: 97 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji3.0x_a_1.jpg
Normal file
After Width: | Height: | Size: 67 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji3.0x_a_2.jpg
Normal file
After Width: | Height: | Size: 122 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji3.0x_a_3.jpg
Normal file
After Width: | Height: | Size: 50 KiB |
BIN
TMessagesProj/src/main/assets/emoji/emoji3.0x_a_4.jpg
Normal file
After Width: | Height: | Size: 102 KiB |
@ -184,10 +184,10 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection.
|
|||||||
if (paused) {
|
if (paused) {
|
||||||
ApplicationLoader.lastPauseTime = System.currentTimeMillis();
|
ApplicationLoader.lastPauseTime = System.currentTimeMillis();
|
||||||
nextSleepTimeout = 30000;
|
nextSleepTimeout = 30000;
|
||||||
FileLog.e("tmessages", "wakeup network in background by recieved push");
|
FileLog.e("tmessages", "wakeup network in background by received push");
|
||||||
} else if (ApplicationLoader.lastPauseTime != 0) {
|
} else if (ApplicationLoader.lastPauseTime != 0) {
|
||||||
ApplicationLoader.lastPauseTime = System.currentTimeMillis();
|
ApplicationLoader.lastPauseTime = System.currentTimeMillis();
|
||||||
FileLog.e("tmessages", "reset sleep timeout by recieved push");
|
FileLog.e("tmessages", "reset sleep timeout by received push");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -849,7 +849,16 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection.
|
|||||||
public static boolean isNetworkOnline() {
|
public static boolean isNetworkOnline() {
|
||||||
try {
|
try {
|
||||||
ConnectivityManager cm = (ConnectivityManager)ApplicationLoader.applicationContext.getSystemService(Context.CONNECTIVITY_SERVICE);
|
ConnectivityManager cm = (ConnectivityManager)ApplicationLoader.applicationContext.getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||||
NetworkInfo netInfo = cm.getNetworkInfo(ConnectivityManager.TYPE_MOBILE);
|
NetworkInfo netInfo = cm.getActiveNetworkInfo();
|
||||||
|
if (netInfo != null && netInfo.isConnected()) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
netInfo = cm.getNetworkInfo(ConnectivityManager.TYPE_MOBILE);
|
||||||
|
if (netInfo.isConnected()) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
if (netInfo != null && netInfo.getState() == NetworkInfo.State.CONNECTED) {
|
if (netInfo != null && netInfo.getState() == NetworkInfo.State.CONNECTED) {
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
|
@ -34,8 +34,12 @@ public class Emoji {
|
|||||||
private static int drawImgSize, bigImgSize;
|
private static int drawImgSize, bigImgSize;
|
||||||
private static boolean inited = false;
|
private static boolean inited = false;
|
||||||
private static Paint placeholderPaint;
|
private static Paint placeholderPaint;
|
||||||
private static Bitmap emojiBmp = null;
|
private static Bitmap emojiBmp[] = new Bitmap[5];
|
||||||
private static boolean loadingEmoji = false;
|
private static boolean loadingEmoji[] = new boolean[5];
|
||||||
|
|
||||||
|
private static final int[] cols = {
|
||||||
|
13, 10, 15, 10, 14
|
||||||
|
};
|
||||||
|
|
||||||
private static final char[] emojiChars = {
|
private static final char[] emojiChars = {
|
||||||
0x00A9, 0x00AE, 0x203C, 0x2049, 0x2122, 0x2139, 0x2194, 0x2195, 0x2196, 0x2197,
|
0x00A9, 0x00AE, 0x203C, 0x2049, 0x2122, 0x2139, 0x2194, 0x2195, 0x2196, 0x2197,
|
||||||
@ -199,19 +203,17 @@ public class Emoji {
|
|||||||
drawImgSize = Utilities.dp(20);
|
drawImgSize = Utilities.dp(20);
|
||||||
bigImgSize = Utilities.dp(30);
|
bigImgSize = Utilities.dp(30);
|
||||||
|
|
||||||
int num = 0;
|
|
||||||
for (int j = 1; j < data.length; j++) {
|
for (int j = 1; j < data.length; j++) {
|
||||||
for (int i = 0; i < data[j].length; i++) {
|
for (int i = 0; i < data[j].length; i++) {
|
||||||
Rect rect = new Rect((num % 29) * imgSize, (num / 29) * imgSize, (num % 29 + 1) * imgSize, (num / 29 + 1) * imgSize);
|
Rect rect = new Rect((i % cols[j - 1]) * imgSize, (i / cols[j - 1]) * imgSize, (i % cols[j - 1] + 1) * imgSize, (i / cols[j - 1] + 1) * imgSize);
|
||||||
rects.put(data[j][i], new DrawableInfo(rect));
|
rects.put(data[j][i], new DrawableInfo(rect, (byte)(j - 1)));
|
||||||
num++;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
placeholderPaint = new Paint();
|
placeholderPaint = new Paint();
|
||||||
placeholderPaint.setColor(0x55000000);
|
placeholderPaint.setColor(0x00000000);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Bitmap loadEmoji() {
|
private static Bitmap loadEmoji(final int page) {
|
||||||
try {
|
try {
|
||||||
float scale = 1.0f;
|
float scale = 1.0f;
|
||||||
int imageResize = 1;
|
int imageResize = 1;
|
||||||
@ -227,7 +229,7 @@ public class Emoji {
|
|||||||
scale = 3.0f;
|
scale = 3.0f;
|
||||||
}
|
}
|
||||||
|
|
||||||
String imageName = String.format(Locale.US, "emoji%.01fx.jpg", scale);
|
String imageName = String.format(Locale.US, "emoji%.01fx_%d.jpg", scale, page);
|
||||||
File imageFile = ApplicationLoader.applicationContext.getFileStreamPath(imageName);
|
File imageFile = ApplicationLoader.applicationContext.getFileStreamPath(imageName);
|
||||||
if (!imageFile.exists()) {
|
if (!imageFile.exists()) {
|
||||||
InputStream is = ApplicationLoader.applicationContext.getAssets().open("emoji/" + imageName);
|
InputStream is = ApplicationLoader.applicationContext.getAssets().open("emoji/" + imageName);
|
||||||
@ -242,7 +244,7 @@ public class Emoji {
|
|||||||
final Bitmap colorsBitmap = Bitmap.createBitmap(opts.outWidth / imageResize, opts.outHeight / imageResize, Bitmap.Config.ARGB_8888);
|
final Bitmap colorsBitmap = Bitmap.createBitmap(opts.outWidth / imageResize, opts.outHeight / imageResize, Bitmap.Config.ARGB_8888);
|
||||||
Utilities.loadBitmap(imageFile.getAbsolutePath(), colorsBitmap, imageResize);
|
Utilities.loadBitmap(imageFile.getAbsolutePath(), colorsBitmap, imageResize);
|
||||||
|
|
||||||
imageName = String.format(Locale.US, "emoji%.01fx_a.jpg", scale);
|
imageName = String.format(Locale.US, "emoji%.01fx_a_%d.jpg", scale, page);
|
||||||
imageFile = ApplicationLoader.applicationContext.getFileStreamPath(imageName);
|
imageFile = ApplicationLoader.applicationContext.getFileStreamPath(imageName);
|
||||||
if (!imageFile.exists()) {
|
if (!imageFile.exists()) {
|
||||||
InputStream is = ApplicationLoader.applicationContext.getAssets().open("emoji/" + imageName);
|
InputStream is = ApplicationLoader.applicationContext.getAssets().open("emoji/" + imageName);
|
||||||
@ -255,7 +257,7 @@ public class Emoji {
|
|||||||
Utilities.RunOnUIThread(new Runnable() {
|
Utilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
emojiBmp = colorsBitmap;
|
emojiBmp[page] = colorsBitmap;
|
||||||
NotificationCenter.getInstance().postNotificationName(999);
|
NotificationCenter.getInstance().postNotificationName(999);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -267,15 +269,15 @@ public class Emoji {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void loadEmojiAsync() {
|
private static void loadEmojiAsync(final int page) {
|
||||||
if (loadingEmoji) {
|
if (loadingEmoji[page]) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
loadingEmoji = true;
|
loadingEmoji[page] = true;
|
||||||
new Thread(new Runnable() {
|
new Thread(new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
loadEmoji();
|
loadEmoji(page);
|
||||||
loadingEmoji = false;
|
loadingEmoji[page] = false;
|
||||||
}
|
}
|
||||||
}).start();
|
}).start();
|
||||||
}
|
}
|
||||||
@ -313,7 +315,7 @@ public class Emoji {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static class EmojiDrawable extends Drawable {
|
public static class EmojiDrawable extends Drawable {
|
||||||
Rect rect;
|
private DrawableInfo info;
|
||||||
boolean fullSize = false;
|
boolean fullSize = false;
|
||||||
private static Paint paint;
|
private static Paint paint;
|
||||||
|
|
||||||
@ -322,14 +324,14 @@ public class Emoji {
|
|||||||
paint.setFlags(Paint.FILTER_BITMAP_FLAG | Paint.ANTI_ALIAS_FLAG);
|
paint.setFlags(Paint.FILTER_BITMAP_FLAG | Paint.ANTI_ALIAS_FLAG);
|
||||||
}
|
}
|
||||||
|
|
||||||
public EmojiDrawable(DrawableInfo info) {
|
public EmojiDrawable(DrawableInfo i) {
|
||||||
rect = info.rect;
|
info = i;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void draw(Canvas canvas) {
|
public void draw(Canvas canvas) {
|
||||||
if (emojiBmp == null) {
|
if (emojiBmp[info.page] == null) {
|
||||||
loadEmojiAsync();
|
loadEmojiAsync(info.page);
|
||||||
canvas.drawRect(getBounds(), placeholderPaint);
|
canvas.drawRect(getBounds(), placeholderPaint);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -340,7 +342,7 @@ public class Emoji {
|
|||||||
b.top = cY - (fullSize ? bigImgSize : drawImgSize) / 2;
|
b.top = cY - (fullSize ? bigImgSize : drawImgSize) / 2;
|
||||||
b.bottom = cY + (fullSize ? bigImgSize : drawImgSize) / 2;
|
b.bottom = cY + (fullSize ? bigImgSize : drawImgSize) / 2;
|
||||||
if (!canvas.quickReject(b.left, b.top, b.right, b.bottom, Canvas.EdgeType.AA)) {
|
if (!canvas.quickReject(b.left, b.top, b.right, b.bottom, Canvas.EdgeType.AA)) {
|
||||||
canvas.drawBitmap(emojiBmp, rect, b, paint);
|
canvas.drawBitmap(emojiBmp[info.page], info.rect, b, paint);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -361,9 +363,12 @@ public class Emoji {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static class DrawableInfo {
|
private static class DrawableInfo {
|
||||||
Rect rect;
|
public Rect rect;
|
||||||
public DrawableInfo(Rect rect) {
|
public byte page;
|
||||||
this.rect = rect;
|
|
||||||
|
public DrawableInfo(Rect r, byte p) {
|
||||||
|
rect = r;
|
||||||
|
page = p;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -93,12 +93,7 @@ public class FileLoadOperation {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public FileLoadOperation(TLRPC.Audio audioLocation) {
|
public FileLoadOperation(TLRPC.Audio audioLocation) {
|
||||||
if (audioLocation instanceof TLRPC.TL_audio) {
|
if (audioLocation instanceof TLRPC.TL_audioEncrypted) {
|
||||||
location = new TLRPC.TL_inputAudioFileLocation();
|
|
||||||
datacenter_id = audioLocation.dc_id;
|
|
||||||
location.id = audioLocation.id;
|
|
||||||
location.access_hash = audioLocation.access_hash;
|
|
||||||
} else if (audioLocation instanceof TLRPC.TL_audioEncrypted) {
|
|
||||||
location = new TLRPC.TL_inputEncryptedFileLocation();
|
location = new TLRPC.TL_inputEncryptedFileLocation();
|
||||||
location.id = audioLocation.id;
|
location.id = audioLocation.id;
|
||||||
location.access_hash = audioLocation.access_hash;
|
location.access_hash = audioLocation.access_hash;
|
||||||
@ -106,6 +101,11 @@ public class FileLoadOperation {
|
|||||||
iv = new byte[32];
|
iv = new byte[32];
|
||||||
System.arraycopy(audioLocation.iv, 0, iv, 0, iv.length);
|
System.arraycopy(audioLocation.iv, 0, iv, 0, iv.length);
|
||||||
key = audioLocation.key;
|
key = audioLocation.key;
|
||||||
|
} else if (audioLocation instanceof TLRPC.TL_audio) {
|
||||||
|
location = new TLRPC.TL_inputAudioFileLocation();
|
||||||
|
datacenter_id = audioLocation.dc_id;
|
||||||
|
location.id = audioLocation.id;
|
||||||
|
location.access_hash = audioLocation.access_hash;
|
||||||
}
|
}
|
||||||
ext = ".m4a";
|
ext = ".m4a";
|
||||||
}
|
}
|
||||||
|
@ -20,7 +20,6 @@ import android.os.ParcelFileDescriptor;
|
|||||||
|
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.objects.MessageObject;
|
||||||
import org.telegram.ui.ApplicationLoader;
|
import org.telegram.ui.ApplicationLoader;
|
||||||
import org.telegram.ui.Views.BackupImageView;
|
|
||||||
import org.telegram.ui.Views.ImageReceiver;
|
import org.telegram.ui.Views.ImageReceiver;
|
||||||
|
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
@ -34,6 +33,7 @@ import java.util.HashMap;
|
|||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.Queue;
|
import java.util.Queue;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
|
import java.util.concurrent.Semaphore;
|
||||||
|
|
||||||
public class FileLoader {
|
public class FileLoader {
|
||||||
public LruCache memCache;
|
public LruCache memCache;
|
||||||
@ -132,10 +132,10 @@ public class FileLoader {
|
|||||||
|
|
||||||
private class CacheImage {
|
private class CacheImage {
|
||||||
public String key;
|
public String key;
|
||||||
final public ArrayList<Object> imageViewArray = new ArrayList<Object>();
|
final public ArrayList<ImageReceiver> imageViewArray = new ArrayList<ImageReceiver>();
|
||||||
public FileLoadOperation loadOperation;
|
public FileLoadOperation loadOperation;
|
||||||
|
|
||||||
public void addImageView(Object imageView) {
|
public void addImageView(ImageReceiver imageView) {
|
||||||
synchronized (imageViewArray) {
|
synchronized (imageViewArray) {
|
||||||
boolean exist = false;
|
boolean exist = false;
|
||||||
for (Object v : imageViewArray) {
|
for (Object v : imageViewArray) {
|
||||||
@ -166,9 +166,7 @@ public class FileLoader {
|
|||||||
synchronized (imageViewArray) {
|
synchronized (imageViewArray) {
|
||||||
if (image != null) {
|
if (image != null) {
|
||||||
for (Object imgView : imageViewArray) {
|
for (Object imgView : imageViewArray) {
|
||||||
if (imgView instanceof BackupImageView) {
|
if (imgView instanceof ImageReceiver) {
|
||||||
((BackupImageView)imgView).setImageBitmap(image, key);
|
|
||||||
} else if (imgView instanceof ImageReceiver) {
|
|
||||||
((ImageReceiver)imgView).setImageBitmap(image, key);
|
((ImageReceiver)imgView).setImageBitmap(image, key);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -481,8 +479,22 @@ public class FileLoader {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isLoadingFile(String fileName) {
|
public boolean isLoadingFile(final String fileName) {
|
||||||
return loadOperationPaths.containsKey(fileName);
|
final Semaphore semaphore = new Semaphore(0);
|
||||||
|
final Boolean[] result = new Boolean[1];
|
||||||
|
fileLoaderQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
result[0] = loadOperationPaths.containsKey(fileName);
|
||||||
|
semaphore.release();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
try {
|
||||||
|
semaphore.acquire();
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
return result[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
public void loadFile(final TLRPC.Video video, final TLRPC.PhotoSize photo, final TLRPC.Document document, final TLRPC.Audio audio) {
|
public void loadFile(final TLRPC.Video video, final TLRPC.PhotoSize photo, final TLRPC.Document document, final TLRPC.Audio audio) {
|
||||||
@ -676,34 +688,16 @@ public class FileLoader {
|
|||||||
memCache.evictAll();
|
memCache.evictAll();
|
||||||
}
|
}
|
||||||
|
|
||||||
private Integer getTag(Object obj) {
|
public void cancelLoadingForImageView(final ImageReceiver imageView) {
|
||||||
if (obj instanceof BackupImageView) {
|
|
||||||
return (Integer)((BackupImageView)obj).getTag(R.string.CacheTag);
|
|
||||||
} else if (obj instanceof ImageReceiver) {
|
|
||||||
return ((ImageReceiver)obj).TAG;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setTag(Object obj, Integer tag) {
|
|
||||||
if (obj instanceof BackupImageView) {
|
|
||||||
((BackupImageView)obj).setTag(R.string.CacheTag, tag);
|
|
||||||
} else if (obj instanceof ImageReceiver) {
|
|
||||||
((ImageReceiver)obj).TAG = tag;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void cancelLoadingForImageView(final Object imageView) {
|
|
||||||
if (imageView == null) {
|
if (imageView == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
fileLoaderQueue.postRunnable(new Runnable() {
|
fileLoaderQueue.postRunnable(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
Integer TAG = getTag(imageView);
|
Integer TAG = imageView.TAG;
|
||||||
if (TAG == null) {
|
if (TAG == null) {
|
||||||
TAG = lastImageNum;
|
imageView.TAG = TAG = lastImageNum;
|
||||||
setTag(imageView, TAG);
|
|
||||||
lastImageNum++;
|
lastImageNum++;
|
||||||
if (lastImageNum == Integer.MAX_VALUE) {
|
if (lastImageNum == Integer.MAX_VALUE) {
|
||||||
lastImageNum = 0;
|
lastImageNum = 0;
|
||||||
@ -723,15 +717,15 @@ public class FileLoader {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public Bitmap getImageFromMemory(TLRPC.FileLocation url, Object imageView, String filter, boolean cancel) {
|
public Bitmap getImageFromMemory(TLRPC.FileLocation url, ImageReceiver imageView, String filter, boolean cancel) {
|
||||||
return getImageFromMemory(url, null, imageView, filter, cancel);
|
return getImageFromMemory(url, null, imageView, filter, cancel);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Bitmap getImageFromMemory(String url, Object imageView, String filter, boolean cancel) {
|
public Bitmap getImageFromMemory(String url, ImageReceiver imageView, String filter, boolean cancel) {
|
||||||
return getImageFromMemory(null, url, imageView, filter, cancel);
|
return getImageFromMemory(null, url, imageView, filter, cancel);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Bitmap getImageFromMemory(TLRPC.FileLocation url, String httpUrl, Object imageView, String filter, boolean cancel) {
|
public Bitmap getImageFromMemory(TLRPC.FileLocation url, String httpUrl, ImageReceiver imageView, String filter, boolean cancel) {
|
||||||
if (url == null && httpUrl == null) {
|
if (url == null && httpUrl == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -783,19 +777,19 @@ public class FileLoader {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public void loadImage(final String url, final Object imageView, final String filter, final boolean cancel) {
|
public void loadImage(final String url, final ImageReceiver imageView, final String filter, final boolean cancel) {
|
||||||
loadImage(null, url, imageView, filter, cancel, 0);
|
loadImage(null, url, imageView, filter, cancel, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void loadImage(final TLRPC.FileLocation url, final Object imageView, final String filter, final boolean cancel) {
|
public void loadImage(final TLRPC.FileLocation url, final ImageReceiver imageView, final String filter, final boolean cancel) {
|
||||||
loadImage(url, null, imageView, filter, cancel, 0);
|
loadImage(url, null, imageView, filter, cancel, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void loadImage(final TLRPC.FileLocation url, final Object imageView, final String filter, final boolean cancel, final int size) {
|
public void loadImage(final TLRPC.FileLocation url, final ImageReceiver imageView, final String filter, final boolean cancel, final int size) {
|
||||||
loadImage(url, null, imageView, filter, cancel, size);
|
loadImage(url, null, imageView, filter, cancel, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void loadImage(final TLRPC.FileLocation url, final String httpUrl, final Object imageView, final String filter, final boolean cancel, final int size) {
|
public void loadImage(final TLRPC.FileLocation url, final String httpUrl, final ImageReceiver imageView, final String filter, final boolean cancel, final int size) {
|
||||||
if ((url == null && httpUrl == null) || imageView == null || (url != null && !(url instanceof TLRPC.TL_fileLocation) && !(url instanceof TLRPC.TL_fileEncryptedLocation))) {
|
if ((url == null && httpUrl == null) || imageView == null || (url != null && !(url instanceof TLRPC.TL_fileLocation) && !(url instanceof TLRPC.TL_fileEncryptedLocation))) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -814,10 +808,9 @@ public class FileLoader {
|
|||||||
key += "@" + filter;
|
key += "@" + filter;
|
||||||
}
|
}
|
||||||
|
|
||||||
Integer TAG = getTag(imageView);
|
Integer TAG = imageView.TAG;
|
||||||
if (TAG == null) {
|
if (TAG == null) {
|
||||||
TAG = lastImageNum;
|
TAG = imageView.TAG = lastImageNum;
|
||||||
setTag(imageView, TAG);
|
|
||||||
lastImageNum++;
|
lastImageNum++;
|
||||||
if (lastImageNum == Integer.MAX_VALUE)
|
if (lastImageNum == Integer.MAX_VALUE)
|
||||||
lastImageNum = 0;
|
lastImageNum = 0;
|
||||||
@ -878,8 +871,8 @@ public class FileLoader {
|
|||||||
if (arg3 != null) {
|
if (arg3 != null) {
|
||||||
loadOperationPaths.remove(arg3);
|
loadOperationPaths.remove(arg3);
|
||||||
}
|
}
|
||||||
for (Object v : img.imageViewArray) {
|
for (ImageReceiver v : img.imageViewArray) {
|
||||||
imageLoadingByKeys.remove(getTag(v));
|
imageLoadingByKeys.remove(v.TAG);
|
||||||
}
|
}
|
||||||
checkOperationsAndClear(img.loadOperation);
|
checkOperationsAndClear(img.loadOperation);
|
||||||
imageLoading.remove(arg2);
|
imageLoading.remove(arg2);
|
||||||
@ -906,8 +899,8 @@ public class FileLoader {
|
|||||||
if (arg3 != null) {
|
if (arg3 != null) {
|
||||||
loadOperationPaths.remove(arg3);
|
loadOperationPaths.remove(arg3);
|
||||||
}
|
}
|
||||||
for (Object view : img.imageViewArray) {
|
for (ImageReceiver view : img.imageViewArray) {
|
||||||
imageLoadingByKeys.remove(getTag(view));
|
imageLoadingByKeys.remove(view.TAG);
|
||||||
imageLoading.remove(arg2);
|
imageLoading.remove(arg2);
|
||||||
checkOperationsAndClear(operation);
|
checkOperationsAndClear(operation);
|
||||||
}
|
}
|
||||||
|
@ -852,7 +852,7 @@ public class MessagesController implements NotificationCenter.NotificationCenter
|
|||||||
|
|
||||||
ArrayList<Long> keys = new ArrayList<Long>(printingUsers.keySet());
|
ArrayList<Long> keys = new ArrayList<Long>(printingUsers.keySet());
|
||||||
for (Long key : keys) {
|
for (Long key : keys) {
|
||||||
if (key > 0) {
|
if (key > 0 || key.intValue() == 0) {
|
||||||
newPrintingStrings.put(key, LocaleController.getString("Typing", R.string.Typing));
|
newPrintingStrings.put(key, LocaleController.getString("Typing", R.string.Typing));
|
||||||
} else {
|
} else {
|
||||||
ArrayList<PrintingUser> arr = printingUsers.get(key);
|
ArrayList<PrintingUser> arr = printingUsers.get(key);
|
||||||
@ -3937,26 +3937,30 @@ public class MessagesController implements NotificationCenter.NotificationCenter
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (update instanceof TLRPC.TL_updateEncryptedChatTyping) {
|
} else if (update instanceof TLRPC.TL_updateEncryptedChatTyping) {
|
||||||
long uid = ((long)update.chat_id) << 32;
|
TLRPC.EncryptedChat encryptedChat = getEncryptedChat(update.chat_id);
|
||||||
ArrayList<PrintingUser> arr = printingUsers.get(uid);
|
if (encryptedChat != null) {
|
||||||
if (arr == null) {
|
update.user_id = encryptedChat.user_id;
|
||||||
arr = new ArrayList<PrintingUser>();
|
long uid = ((long) update.chat_id) << 32;
|
||||||
printingUsers.put(uid, arr);
|
ArrayList<PrintingUser> arr = printingUsers.get(uid);
|
||||||
}
|
if (arr == null) {
|
||||||
boolean exist = false;
|
arr = new ArrayList<PrintingUser>();
|
||||||
for (PrintingUser u : arr) {
|
printingUsers.put(uid, arr);
|
||||||
if (u.userId == update.user_id) {
|
}
|
||||||
exist = true;
|
boolean exist = false;
|
||||||
u.lastTime = currentTime;
|
for (PrintingUser u : arr) {
|
||||||
break;
|
if (u.userId == update.user_id) {
|
||||||
|
exist = true;
|
||||||
|
u.lastTime = currentTime;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!exist) {
|
||||||
|
PrintingUser newUser = new PrintingUser();
|
||||||
|
newUser.userId = update.user_id;
|
||||||
|
newUser.lastTime = currentTime;
|
||||||
|
arr.add(newUser);
|
||||||
|
printChanged = true;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
if (!exist) {
|
|
||||||
PrintingUser newUser = new PrintingUser();
|
|
||||||
newUser.userId = update.user_id;
|
|
||||||
newUser.lastTime = currentTime;
|
|
||||||
arr.add(newUser);
|
|
||||||
printChanged = true;
|
|
||||||
}
|
}
|
||||||
} else if (update instanceof TLRPC.TL_updateEncryptedMessagesRead) {
|
} else if (update instanceof TLRPC.TL_updateEncryptedMessagesRead) {
|
||||||
markAsReadEncrypted.put(update.chat_id, Math.max(update.max_date, update.date));
|
markAsReadEncrypted.put(update.chat_id, Math.max(update.max_date, update.date));
|
||||||
@ -3970,22 +3974,7 @@ public class MessagesController implements NotificationCenter.NotificationCenter
|
|||||||
} else if (update instanceof TLRPC.TL_updateEncryption) {
|
} else if (update instanceof TLRPC.TL_updateEncryption) {
|
||||||
final TLRPC.EncryptedChat newChat = update.chat;
|
final TLRPC.EncryptedChat newChat = update.chat;
|
||||||
long dialog_id = ((long)newChat.id) << 32;
|
long dialog_id = ((long)newChat.id) << 32;
|
||||||
TLRPC.EncryptedChat existingChat = encryptedChats.get(newChat.id);
|
TLRPC.EncryptedChat existingChat = getEncryptedChat(newChat.id);
|
||||||
if (existingChat == null) {
|
|
||||||
Semaphore semaphore = new Semaphore(0);
|
|
||||||
ArrayList<TLObject> result = new ArrayList<TLObject>();
|
|
||||||
MessagesStorage.getInstance().getEncryptedChat(newChat.id, semaphore, result);
|
|
||||||
try {
|
|
||||||
semaphore.acquire();
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
}
|
|
||||||
if (result.size() == 2) {
|
|
||||||
existingChat = (TLRPC.EncryptedChat)result.get(0);
|
|
||||||
TLRPC.User user = (TLRPC.User)result.get(1);
|
|
||||||
users.putIfAbsent(user.id, user);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (newChat instanceof TLRPC.TL_encryptedChatRequested && existingChat == null) {
|
if (newChat instanceof TLRPC.TL_encryptedChatRequested && existingChat == null) {
|
||||||
int user_id = newChat.participant_id;
|
int user_id = newChat.participant_id;
|
||||||
@ -4289,7 +4278,7 @@ public class MessagesController implements NotificationCenter.NotificationCenter
|
|||||||
}
|
}
|
||||||
if (ApplicationLoader.lastPauseTime != 0) {
|
if (ApplicationLoader.lastPauseTime != 0) {
|
||||||
ApplicationLoader.lastPauseTime = System.currentTimeMillis();
|
ApplicationLoader.lastPauseTime = System.currentTimeMillis();
|
||||||
FileLog.e("tmessages", "reset sleep timeout by recieved message");
|
FileLog.e("tmessages", "reset sleep timeout by received message");
|
||||||
}
|
}
|
||||||
if (messageObject == null) {
|
if (messageObject == null) {
|
||||||
return;
|
return;
|
||||||
@ -4654,12 +4643,12 @@ public class MessagesController implements NotificationCenter.NotificationCenter
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public TLRPC.Message decryptMessage(TLRPC.EncryptedMessage message) {
|
public TLRPC.EncryptedChat getEncryptedChat(int chat_id) {
|
||||||
TLRPC.EncryptedChat chat = encryptedChats.get(message.chat_id);
|
TLRPC.EncryptedChat chat = encryptedChats.get(chat_id);
|
||||||
if (chat == null) {
|
if (chat == null) {
|
||||||
Semaphore semaphore = new Semaphore(0);
|
Semaphore semaphore = new Semaphore(0);
|
||||||
ArrayList<TLObject> result = new ArrayList<TLObject>();
|
ArrayList<TLObject> result = new ArrayList<TLObject>();
|
||||||
MessagesStorage.getInstance().getEncryptedChat(message.chat_id, semaphore, result);
|
MessagesStorage.getInstance().getEncryptedChat(chat_id, semaphore, result);
|
||||||
try {
|
try {
|
||||||
semaphore.acquire();
|
semaphore.acquire();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
@ -4672,6 +4661,11 @@ public class MessagesController implements NotificationCenter.NotificationCenter
|
|||||||
users.putIfAbsent(user.id, user);
|
users.putIfAbsent(user.id, user);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return chat;
|
||||||
|
}
|
||||||
|
|
||||||
|
public TLRPC.Message decryptMessage(TLRPC.EncryptedMessage message) {
|
||||||
|
TLRPC.EncryptedChat chat = getEncryptedChat(message.chat_id);
|
||||||
if (chat == null) {
|
if (chat == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -15,8 +15,6 @@ public class NotificationCenter {
|
|||||||
|
|
||||||
final private HashMap<Integer, ArrayList<Object>> observers = new HashMap<Integer, ArrayList<Object>>();
|
final private HashMap<Integer, ArrayList<Object>> observers = new HashMap<Integer, ArrayList<Object>>();
|
||||||
|
|
||||||
final private HashMap<String, Object> memCache = new HashMap<String, Object>();
|
|
||||||
|
|
||||||
final private HashMap<Integer, Object> removeAfterBroadcast = new HashMap<Integer, Object>();
|
final private HashMap<Integer, Object> removeAfterBroadcast = new HashMap<Integer, Object>();
|
||||||
final private HashMap<Integer, Object> addAfterBroadcast = new HashMap<Integer, Object>();
|
final private HashMap<Integer, Object> addAfterBroadcast = new HashMap<Integer, Object>();
|
||||||
|
|
||||||
@ -40,27 +38,6 @@ public class NotificationCenter {
|
|||||||
public abstract void didReceivedNotification(int id, Object... args);
|
public abstract void didReceivedNotification(int id, Object... args);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addToMemCache(int id, Object object) {
|
|
||||||
addToMemCache(String.valueOf(id), object);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addToMemCache(String id, Object object) {
|
|
||||||
memCache.put(id, object);
|
|
||||||
}
|
|
||||||
|
|
||||||
public Object getFromMemCache(int id) {
|
|
||||||
return getFromMemCache(String.valueOf(id), null);
|
|
||||||
}
|
|
||||||
|
|
||||||
public Object getFromMemCache(String id, Object defaultValue) {
|
|
||||||
Object obj = memCache.get(id);
|
|
||||||
if (obj != null) {
|
|
||||||
memCache.remove(id);
|
|
||||||
return obj;
|
|
||||||
}
|
|
||||||
return defaultValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void postNotificationName(int id, Object... args) {
|
public void postNotificationName(int id, Object... args) {
|
||||||
synchronized (observers) {
|
synchronized (observers) {
|
||||||
broadcasting = true;
|
broadcasting = true;
|
||||||
|
@ -59,7 +59,6 @@ public class TcpConnection extends ConnectionContext {
|
|||||||
private boolean firstPacket;
|
private boolean firstPacket;
|
||||||
|
|
||||||
private Timer reconnectTimer;
|
private Timer reconnectTimer;
|
||||||
private boolean tryWithNoNetworkAnyway = false;
|
|
||||||
|
|
||||||
public TcpConnection(int did) {
|
public TcpConnection(int did) {
|
||||||
if (selector == null) {
|
if (selector == null) {
|
||||||
@ -81,6 +80,43 @@ public class TcpConnection extends ConnectionContext {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void connect() {
|
public void connect() {
|
||||||
|
if (!ConnectionsManager.isNetworkOnline()) {
|
||||||
|
synchronized (timerSync) {
|
||||||
|
reconnectTimer = new Timer();
|
||||||
|
reconnectTimer.schedule(new TimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
selector.scheduleTask(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
synchronized (timerSync) {
|
||||||
|
if (reconnectTimer != null) {
|
||||||
|
reconnectTimer.cancel();
|
||||||
|
reconnectTimer = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (Exception e2) {
|
||||||
|
FileLog.e("tmessages", e2);
|
||||||
|
}
|
||||||
|
connect();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}, 500);
|
||||||
|
}
|
||||||
|
if (delegate != null) {
|
||||||
|
final TcpConnectionDelegate finalDelegate = delegate;
|
||||||
|
Utilities.stageQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
finalDelegate.tcpConnectionClosed(TcpConnection.this);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
selector.scheduleTask(new Runnable() {
|
selector.scheduleTask(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
@ -94,14 +130,6 @@ public class TcpConnection extends ConnectionContext {
|
|||||||
hostAddress = datacenter.getCurrentAddress();
|
hostAddress = datacenter.getCurrentAddress();
|
||||||
hostPort = datacenter.getCurrentPort();
|
hostPort = datacenter.getCurrentPort();
|
||||||
|
|
||||||
if(android.os.Build.VERSION.SDK_INT < 11) {
|
|
||||||
if (!ConnectionsManager.isNetworkOnline() && !tryWithNoNetworkAnyway) {
|
|
||||||
handleConnectionError(null);
|
|
||||||
tryWithNoNetworkAnyway = true;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
tryWithNoNetworkAnyway = false;
|
|
||||||
}
|
|
||||||
try {
|
try {
|
||||||
synchronized (timerSync) {
|
synchronized (timerSync) {
|
||||||
if (reconnectTimer != null) {
|
if (reconnectTimer != null) {
|
||||||
@ -637,28 +665,30 @@ public class TcpConnection extends ConnectionContext {
|
|||||||
}
|
}
|
||||||
FileLog.d("tmessages", "Reconnect " + hostAddress + ":" + hostPort + " " + TcpConnection.this);
|
FileLog.d("tmessages", "Reconnect " + hostAddress + ":" + hostPort + " " + TcpConnection.this);
|
||||||
try {
|
try {
|
||||||
reconnectTimer = new Timer();
|
synchronized (timerSync) {
|
||||||
reconnectTimer.schedule(new TimerTask() {
|
reconnectTimer = new Timer();
|
||||||
@Override
|
reconnectTimer.schedule(new TimerTask() {
|
||||||
public void run() {
|
@Override
|
||||||
selector.scheduleTask(new Runnable() {
|
public void run() {
|
||||||
@Override
|
selector.scheduleTask(new Runnable() {
|
||||||
public void run() {
|
@Override
|
||||||
try {
|
public void run() {
|
||||||
synchronized (timerSync) {
|
try {
|
||||||
if (reconnectTimer != null) {
|
synchronized (timerSync) {
|
||||||
reconnectTimer.cancel();
|
if (reconnectTimer != null) {
|
||||||
reconnectTimer = null;
|
reconnectTimer.cancel();
|
||||||
|
reconnectTimer = null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
} catch (Exception e2) {
|
||||||
|
FileLog.e("tmessages", e2);
|
||||||
}
|
}
|
||||||
} catch (Exception e2) {
|
connect();
|
||||||
FileLog.e("tmessages", e2);
|
|
||||||
}
|
}
|
||||||
connect();
|
});
|
||||||
}
|
}
|
||||||
});
|
}, failedConnectionCount > 3 ? 500 : 300, failedConnectionCount > 3 ? 500 : 300);
|
||||||
}
|
}
|
||||||
}, failedConnectionCount > 3 ? 500 : 300, failedConnectionCount > 3 ? 500 : 300);
|
|
||||||
} catch (Exception e3) {
|
} catch (Exception e3) {
|
||||||
FileLog.e("tmessages", e3);
|
FileLog.e("tmessages", e3);
|
||||||
}
|
}
|
||||||
|
@ -14,6 +14,7 @@ import android.content.ContentUris;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
|
import android.content.pm.ActivityInfo;
|
||||||
import android.database.Cursor;
|
import android.database.Cursor;
|
||||||
import android.graphics.Bitmap;
|
import android.graphics.Bitmap;
|
||||||
import android.graphics.Point;
|
import android.graphics.Point;
|
||||||
@ -27,6 +28,7 @@ import android.text.Html;
|
|||||||
import android.text.SpannableStringBuilder;
|
import android.text.SpannableStringBuilder;
|
||||||
import android.util.Base64;
|
import android.util.Base64;
|
||||||
import android.view.Display;
|
import android.view.Display;
|
||||||
|
import android.view.Surface;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.WindowManager;
|
import android.view.WindowManager;
|
||||||
import android.view.inputmethod.InputMethodManager;
|
import android.view.inputmethod.InputMethodManager;
|
||||||
@ -72,6 +74,7 @@ public class Utilities {
|
|||||||
public static Pattern pattern = Pattern.compile("[0-9]+");
|
public static Pattern pattern = Pattern.compile("[0-9]+");
|
||||||
public static SecureRandom random = new SecureRandom();
|
public static SecureRandom random = new SecureRandom();
|
||||||
private final static Integer lock = 1;
|
private final static Integer lock = 1;
|
||||||
|
private static int prevOrientation = -10;
|
||||||
|
|
||||||
private static boolean waitingForSms = false;
|
private static boolean waitingForSms = false;
|
||||||
private static final Integer smsLock = 2;
|
private static final Integer smsLock = 2;
|
||||||
@ -152,6 +155,47 @@ public class Utilities {
|
|||||||
public native static void aesIgeEncryption2(ByteBuffer _what, byte[] _key, byte[] _iv, boolean encrypt, boolean changeIv, int len);
|
public native static void aesIgeEncryption2(ByteBuffer _what, byte[] _key, byte[] _iv, boolean encrypt, boolean changeIv, int len);
|
||||||
public native static void loadBitmap(String path, Bitmap bitmap, int scale);
|
public native static void loadBitmap(String path, Bitmap bitmap, int scale);
|
||||||
|
|
||||||
|
public static void lockOrientation(Activity activity) {
|
||||||
|
if (prevOrientation != -10) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
prevOrientation = activity.getRequestedOrientation();
|
||||||
|
WindowManager manager = (WindowManager)activity.getSystemService(Activity.WINDOW_SERVICE);
|
||||||
|
if (manager != null && manager.getDefaultDisplay() != null) {
|
||||||
|
int rotation = manager.getDefaultDisplay().getRotation();
|
||||||
|
if (rotation == Surface.ROTATION_270) {
|
||||||
|
if (Build.VERSION.SDK_INT >= 9) {
|
||||||
|
activity.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_REVERSE_LANDSCAPE);
|
||||||
|
} else {
|
||||||
|
activity.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
|
||||||
|
}
|
||||||
|
} else if (rotation == Surface.ROTATION_90) {
|
||||||
|
activity.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
|
||||||
|
} else if (rotation == Surface.ROTATION_0) {
|
||||||
|
activity.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
|
||||||
|
} else {
|
||||||
|
if (Build.VERSION.SDK_INT >= 9) {
|
||||||
|
activity.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_REVERSE_PORTRAIT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void unlockOrientation(Activity activity) {
|
||||||
|
try {
|
||||||
|
if (prevOrientation != -10) {
|
||||||
|
activity.setRequestedOrientation(prevOrientation);
|
||||||
|
prevOrientation = -10;
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static boolean isWaitingForSms() {
|
public static boolean isWaitingForSms() {
|
||||||
boolean value = false;
|
boolean value = false;
|
||||||
synchronized (smsLock) {
|
synchronized (smsLock) {
|
||||||
|
@ -152,10 +152,12 @@ public class ApplicationLoader extends Application {
|
|||||||
if (preferences.getBoolean("pushService", true)) {
|
if (preferences.getBoolean("pushService", true)) {
|
||||||
applicationContext.startService(new Intent(applicationContext, NotificationsService.class));
|
applicationContext.startService(new Intent(applicationContext, NotificationsService.class));
|
||||||
|
|
||||||
Calendar cal = Calendar.getInstance();
|
if (android.os.Build.VERSION.SDK_INT >= 19) {
|
||||||
PendingIntent pintent = PendingIntent.getService(applicationContext, 0, new Intent(applicationContext, NotificationsService.class), 0);
|
Calendar cal = Calendar.getInstance();
|
||||||
AlarmManager alarm = (AlarmManager) applicationContext.getSystemService(Context.ALARM_SERVICE);
|
PendingIntent pintent = PendingIntent.getService(applicationContext, 0, new Intent(applicationContext, NotificationsService.class), 0);
|
||||||
alarm.setRepeating(AlarmManager.RTC_WAKEUP, cal.getTimeInMillis(), 30000, pintent);
|
AlarmManager alarm = (AlarmManager) applicationContext.getSystemService(Context.ALARM_SERVICE);
|
||||||
|
alarm.setRepeating(AlarmManager.RTC_WAKEUP, cal.getTimeInMillis(), 30000, pintent);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
stopPushService();
|
stopPushService();
|
||||||
}
|
}
|
||||||
|
@ -28,6 +28,7 @@ import org.telegram.messenger.R;
|
|||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.objects.MessageObject;
|
||||||
import org.telegram.objects.PhotoObject;
|
import org.telegram.objects.PhotoObject;
|
||||||
|
import org.telegram.ui.PhotoViewer;
|
||||||
import org.telegram.ui.Views.GifDrawable;
|
import org.telegram.ui.Views.GifDrawable;
|
||||||
import org.telegram.ui.Views.ImageReceiver;
|
import org.telegram.ui.Views.ImageReceiver;
|
||||||
import org.telegram.ui.Views.ProgressView;
|
import org.telegram.ui.Views.ProgressView;
|
||||||
@ -39,7 +40,7 @@ import java.util.Locale;
|
|||||||
public class ChatMediaCell extends ChatBaseCell implements MediaController.FileDownloadProgressListener {
|
public class ChatMediaCell extends ChatBaseCell implements MediaController.FileDownloadProgressListener {
|
||||||
|
|
||||||
public static interface ChatMediaCellDelegate {
|
public static interface ChatMediaCellDelegate {
|
||||||
public abstract void didPressedImage(ChatMediaCell cell, ImageReceiver imageReceiver);
|
public abstract void didPressedImage(ChatMediaCell cell);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Drawable placeholderInDrawable;
|
private static Drawable placeholderInDrawable;
|
||||||
@ -196,7 +197,7 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
if (currentMessageObject.type == 1) {
|
if (currentMessageObject.type == 1) {
|
||||||
if (buttonState == -1) {
|
if (buttonState == -1) {
|
||||||
if (mediaDelegate != null) {
|
if (mediaDelegate != null) {
|
||||||
mediaDelegate.didPressedImage(this, photoImage);
|
mediaDelegate.didPressedImage(this);
|
||||||
}
|
}
|
||||||
} else if (buttonState == 0) {
|
} else if (buttonState == 0) {
|
||||||
didPressedButton();
|
didPressedButton();
|
||||||
@ -217,7 +218,7 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
}
|
}
|
||||||
} else if (currentMessageObject.type == 4) {
|
} else if (currentMessageObject.type == 4) {
|
||||||
if (mediaDelegate != null) {
|
if (mediaDelegate != null) {
|
||||||
mediaDelegate.didPressedImage(this, photoImage);
|
mediaDelegate.didPressedImage(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -271,7 +272,7 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
}
|
}
|
||||||
} else if (buttonState == 3) {
|
} else if (buttonState == 3) {
|
||||||
if (mediaDelegate != null) {
|
if (mediaDelegate != null) {
|
||||||
mediaDelegate.didPressedImage(this, photoImage);
|
mediaDelegate.didPressedImage(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -421,6 +422,10 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
updateButtonState();
|
updateButtonState();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ImageReceiver getPhotoImage() {
|
||||||
|
return photoImage;
|
||||||
|
}
|
||||||
|
|
||||||
public void updateButtonState() {
|
public void updateButtonState() {
|
||||||
String fileName = null;
|
String fileName = null;
|
||||||
File cacheFile = null;
|
File cacheFile = null;
|
||||||
@ -544,6 +549,7 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
gifDrawable.draw(canvas);
|
gifDrawable.draw(canvas);
|
||||||
canvas.restore();
|
canvas.restore();
|
||||||
} else {
|
} else {
|
||||||
|
photoImage.setVisible(!PhotoViewer.getInstance().isShowingImage(currentMessageObject), false);
|
||||||
photoImage.draw(canvas, photoImage.imageX, photoImage.imageY, photoWidth, photoHeight);
|
photoImage.draw(canvas, photoImage.imageX, photoImage.imageY, photoWidth, photoHeight);
|
||||||
drawTime = photoImage.getVisible();
|
drawTime = photoImage.getVisible();
|
||||||
}
|
}
|
||||||
|
@ -15,7 +15,6 @@ import android.content.Context;
|
|||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.content.pm.ActivityInfo;
|
|
||||||
import android.content.pm.ApplicationInfo;
|
import android.content.pm.ApplicationInfo;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
@ -26,7 +25,6 @@ import android.graphics.drawable.BitmapDrawable;
|
|||||||
import android.media.MediaPlayer;
|
import android.media.MediaPlayer;
|
||||||
import android.media.ThumbnailUtils;
|
import android.media.ThumbnailUtils;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.PowerManager;
|
import android.os.PowerManager;
|
||||||
import android.provider.MediaStore;
|
import android.provider.MediaStore;
|
||||||
@ -103,7 +101,7 @@ import java.util.Comparator;
|
|||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.concurrent.Semaphore;
|
import java.util.concurrent.Semaphore;
|
||||||
|
|
||||||
public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLayout.SizeNotifierRelativeLayoutDelegate, NotificationCenter.NotificationCenterDelegate, MessagesActivity.MessagesActivityDelegate, DocumentSelectActivity.DocumentSelectActivityDelegate {
|
public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLayout.SizeNotifierRelativeLayoutDelegate, NotificationCenter.NotificationCenterDelegate, MessagesActivity.MessagesActivityDelegate, DocumentSelectActivity.DocumentSelectActivityDelegate, PhotoViewer.PhotoViewerProvider {
|
||||||
|
|
||||||
private View timeItem;
|
private View timeItem;
|
||||||
private View menuItem;
|
private View menuItem;
|
||||||
@ -180,7 +178,6 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
private float startedDraggingX = -1;
|
private float startedDraggingX = -1;
|
||||||
private float distCanMove = Utilities.dp(80);
|
private float distCanMove = Utilities.dp(80);
|
||||||
private PowerManager.WakeLock mWakeLock = null;
|
private PowerManager.WakeLock mWakeLock = null;
|
||||||
private int prevOrientation = -10;
|
|
||||||
|
|
||||||
private String currentPicturePath;
|
private String currentPicturePath;
|
||||||
|
|
||||||
@ -411,14 +408,7 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
try {
|
Utilities.unlockOrientation(getParentActivity());
|
||||||
if (prevOrientation != -10) {
|
|
||||||
getParentActivity().setRequestedOrientation(prevOrientation);
|
|
||||||
prevOrientation = -10;
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
}
|
|
||||||
MediaController.getInstance().stopAudio();
|
MediaController.getInstance().stopAudio();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -496,18 +486,17 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
}
|
}
|
||||||
presentFragment(new UserProfileActivity(args));
|
presentFragment(new UserProfileActivity(args));
|
||||||
} else if (currentChat != null) {
|
} else if (currentChat != null) {
|
||||||
if (info != null) {
|
if (info != null && info instanceof TLRPC.TL_chatParticipantsForbidden) {
|
||||||
if (info instanceof TLRPC.TL_chatParticipantsForbidden) {
|
return;
|
||||||
return;
|
|
||||||
}
|
|
||||||
NotificationCenter.getInstance().addToMemCache(5, info);
|
|
||||||
}
|
}
|
||||||
if (currentChat.participants_count == 0 || currentChat.left || currentChat instanceof TLRPC.TL_chatForbidden) {
|
if (currentChat.participants_count == 0 || currentChat.left || currentChat instanceof TLRPC.TL_chatForbidden) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Bundle args = new Bundle();
|
Bundle args = new Bundle();
|
||||||
args.putInt("chat_id", currentChat.id);
|
args.putInt("chat_id", currentChat.id);
|
||||||
presentFragment(new ChatProfileActivity(args));
|
ChatProfileActivity fragment = new ChatProfileActivity(args);
|
||||||
|
fragment.setChatInfo(info);
|
||||||
|
presentFragment(fragment);
|
||||||
}
|
}
|
||||||
} else if (id == copy) {
|
} else if (id == copy) {
|
||||||
String str = "";
|
String str = "";
|
||||||
@ -1066,30 +1055,7 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
try {
|
Utilities.lockOrientation(getParentActivity());
|
||||||
prevOrientation = getParentActivity().getRequestedOrientation();
|
|
||||||
WindowManager manager = (WindowManager)ApplicationLoader.applicationContext.getSystemService(Activity.WINDOW_SERVICE);
|
|
||||||
if (manager != null && manager.getDefaultDisplay() != null) {
|
|
||||||
int rotation = manager.getDefaultDisplay().getRotation();
|
|
||||||
if (rotation == Surface.ROTATION_270) {
|
|
||||||
if (Build.VERSION.SDK_INT >= 9) {
|
|
||||||
getParentActivity().setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_REVERSE_LANDSCAPE);
|
|
||||||
} else {
|
|
||||||
getParentActivity().setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
|
|
||||||
}
|
|
||||||
} else if (rotation == Surface.ROTATION_90) {
|
|
||||||
getParentActivity().setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
|
|
||||||
} else if (rotation == Surface.ROTATION_0) {
|
|
||||||
getParentActivity().setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
|
|
||||||
} else {
|
|
||||||
if (Build.VERSION.SDK_INT >= 9) {
|
|
||||||
getParentActivity().setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_REVERSE_PORTRAIT);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
}
|
|
||||||
|
|
||||||
recordPanel.setVisibility(View.VISIBLE);
|
recordPanel.setVisibility(View.VISIBLE);
|
||||||
recordTimeText.setText("00:00");
|
recordTimeText.setText("00:00");
|
||||||
@ -1128,14 +1094,7 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
try {
|
Utilities.unlockOrientation(getParentActivity());
|
||||||
if (prevOrientation != -10) {
|
|
||||||
getParentActivity().setRequestedOrientation(prevOrientation);
|
|
||||||
prevOrientation = -10;
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
}
|
|
||||||
if(android.os.Build.VERSION.SDK_INT > 13) {
|
if(android.os.Build.VERSION.SDK_INT > 13) {
|
||||||
recordPanel.animate().setInterpolator(new AccelerateDecelerateInterpolator()).setListener(new Animator.AnimatorListener() {
|
recordPanel.animate().setInterpolator(new AccelerateDecelerateInterpolator()).setListener(new Animator.AnimatorListener() {
|
||||||
@Override
|
@Override
|
||||||
@ -3367,6 +3326,51 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
showAlertDialog(builder);
|
showAlertDialog(builder);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public PhotoViewer.PlaceProviderObject getPlaceForPhoto(MessageObject messageObject, TLRPC.FileLocation fileLocation) {
|
||||||
|
if (messageObject == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
int count = chatListView.getChildCount();
|
||||||
|
|
||||||
|
for (int a = 0; a < count; a++) {
|
||||||
|
MessageObject messageToOpen = null;
|
||||||
|
ImageReceiver imageReceiver = null;
|
||||||
|
View view = chatListView.getChildAt(a);
|
||||||
|
if (view instanceof ChatMediaCell) {
|
||||||
|
ChatMediaCell cell = (ChatMediaCell)view;
|
||||||
|
MessageObject message = cell.getMessageObject();
|
||||||
|
if (message != null && message.messageOwner.id == messageObject.messageOwner.id) {
|
||||||
|
messageToOpen = message;
|
||||||
|
imageReceiver = cell.getPhotoImage();
|
||||||
|
}
|
||||||
|
} else if (view.getTag() != null) {
|
||||||
|
Object tag = view.getTag();
|
||||||
|
if (tag instanceof ChatListRowHolderEx) {
|
||||||
|
ChatListRowHolderEx holder = (ChatListRowHolderEx)tag;
|
||||||
|
if (holder.message != null && holder.message.messageOwner.id == messageObject.messageOwner.id) {
|
||||||
|
messageToOpen = holder.message;
|
||||||
|
imageReceiver = holder.photoImage.imageReceiver;
|
||||||
|
view = holder.photoImage;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (messageToOpen != null) {
|
||||||
|
int coords[] = new int[2];
|
||||||
|
view.getLocationInWindow(coords);
|
||||||
|
PhotoViewer.PlaceProviderObject object = new PhotoViewer.PlaceProviderObject();
|
||||||
|
object.viewX = coords[0];
|
||||||
|
object.viewY = coords[1] - Utilities.statusBarHeight;
|
||||||
|
object.parentView = chatListView;
|
||||||
|
object.imageReceiver = imageReceiver;
|
||||||
|
object.thumb = object.imageReceiver.getBitmap();
|
||||||
|
return object;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
private class ChatAdapter extends BaseAdapter {
|
private class ChatAdapter extends BaseAdapter {
|
||||||
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
@ -3517,7 +3521,7 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
if (view instanceof ChatMediaCell) {
|
if (view instanceof ChatMediaCell) {
|
||||||
((ChatMediaCell)view).mediaDelegate = new ChatMediaCell.ChatMediaCellDelegate() {
|
((ChatMediaCell)view).mediaDelegate = new ChatMediaCell.ChatMediaCellDelegate() {
|
||||||
@Override
|
@Override
|
||||||
public void didPressedImage(ChatMediaCell cell, ImageReceiver imageReceiver) {
|
public void didPressedImage(ChatMediaCell cell) {
|
||||||
MessageObject message = cell.getMessageObject();
|
MessageObject message = cell.getMessageObject();
|
||||||
if (message.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SEND_ERROR) {
|
if (message.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SEND_ERROR) {
|
||||||
createMenu(cell, false);
|
createMenu(cell, false);
|
||||||
@ -3526,12 +3530,7 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (message.type == 1) {
|
if (message.type == 1) {
|
||||||
// int coords[] = new int[2];
|
PhotoViewer.getInstance().openPhoto(message, ChatActivity.this);
|
||||||
// cell.getLocationInWindow(coords);
|
|
||||||
// PhotoViewer.getInstance().openPhoto(imageReceiver, coords[0], coords[1] - Utilities.statusBarHeight, chatListView);
|
|
||||||
NotificationCenter.getInstance().addToMemCache(51, message);
|
|
||||||
Intent intent = new Intent(getParentActivity(), GalleryImageViewer.class);
|
|
||||||
getParentActivity().startActivity(intent);
|
|
||||||
} else if (message.type == 3) {
|
} else if (message.type == 3) {
|
||||||
try {
|
try {
|
||||||
File f = null;
|
File f = null;
|
||||||
@ -3551,8 +3550,9 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
if (!isGoogleMapsInstalled()) {
|
if (!isGoogleMapsInstalled()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
NotificationCenter.getInstance().addToMemCache(0, message);
|
LocationActivity fragment = new LocationActivity();
|
||||||
presentFragment(new LocationActivity());
|
fragment.setMessageObject(message);
|
||||||
|
presentFragment(fragment);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -3641,7 +3641,6 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
|
|
||||||
private PhotoObject photoObjectToSet = null;
|
private PhotoObject photoObjectToSet = null;
|
||||||
private File photoFile = null;
|
private File photoFile = null;
|
||||||
private String photoFileName = null;
|
|
||||||
private String photoFilter = null;
|
private String photoFilter = null;
|
||||||
|
|
||||||
public void update() {
|
public void update() {
|
||||||
@ -3683,6 +3682,7 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
photoImage.setImage(photo.photoOwner.location, "50_50", Utilities.getGroupAvatarForId(currentChat.id));
|
photoImage.setImage(photo.photoOwner.location, "50_50", Utilities.getGroupAvatarForId(currentChat.id));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
photoImage.imageReceiver.setVisible(!PhotoViewer.getInstance().isShowingImage(message), false);
|
||||||
}
|
}
|
||||||
} else if (type == 12 || type == 13) {
|
} else if (type == 12 || type == 13) {
|
||||||
TLRPC.User contactUser = MessagesController.getInstance().users.get(message.messageOwner.media.user_id);
|
TLRPC.User contactUser = MessagesController.getInstance().users.get(message.messageOwner.media.user_id);
|
||||||
@ -3753,9 +3753,9 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
phoneTextView.setText(String.format("%.1f MB %s", document.size / 1024.0f / 1024.0f, ext));
|
phoneTextView.setText(String.format("%.1f MB %s", document.size / 1024.0f / 1024.0f, ext));
|
||||||
}
|
}
|
||||||
if (document.thumb instanceof TLRPC.TL_photoSize) {
|
if (document.thumb instanceof TLRPC.TL_photoSize) {
|
||||||
|
contactAvatar.setImage(document.thumb.location, "50_50", type == 8 ? R.drawable.doc_green : R.drawable.doc_blue);
|
||||||
} else if (document.thumb instanceof TLRPC.TL_photoCachedSize) {
|
} else if (document.thumb instanceof TLRPC.TL_photoCachedSize) {
|
||||||
|
contactAvatar.setImage(document.thumb.location, "50_50", type == 8 ? R.drawable.doc_green : R.drawable.doc_blue);
|
||||||
} else {
|
} else {
|
||||||
if (type == 8) {
|
if (type == 8) {
|
||||||
contactAvatar.setImageResource(R.drawable.doc_green);
|
contactAvatar.setImageResource(R.drawable.doc_green);
|
||||||
@ -3843,12 +3843,7 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
if (file != null) {
|
if (file != null) {
|
||||||
progressBarMap.remove(file);
|
progressBarMap.remove(file);
|
||||||
}
|
}
|
||||||
String fileName = null;
|
String fileName = message.getFileName();
|
||||||
if (photoFileName != null) {
|
|
||||||
fileName = photoFileName;
|
|
||||||
} else {
|
|
||||||
fileName = message.getFileName();
|
|
||||||
}
|
|
||||||
boolean load = false;
|
boolean load = false;
|
||||||
if (message.type != 2 && message.type != 3 && message.messageOwner.attachPath != null && message.messageOwner.attachPath.length() != 0) {
|
if (message.type != 2 && message.type != 3 && message.messageOwner.attachPath != null && message.messageOwner.attachPath.length() != 0) {
|
||||||
File f = new File(message.messageOwner.attachPath);
|
File f = new File(message.messageOwner.attachPath);
|
||||||
@ -3895,9 +3890,6 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
addToLoadingFile(fileName, actionProgress);
|
addToLoadingFile(fileName, actionProgress);
|
||||||
if (actionView != null) {
|
if (actionView != null) {
|
||||||
actionView.setVisibility(View.VISIBLE);
|
actionView.setVisibility(View.VISIBLE);
|
||||||
if (photoFileName != null) {
|
|
||||||
actionCancelButton.setImageResource(R.drawable.photo_download_cancel_states);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (actionAttachButton != null) {
|
if (actionAttachButton != null) {
|
||||||
actionAttachButton.setVisibility(View.GONE);
|
actionAttachButton.setVisibility(View.GONE);
|
||||||
@ -4160,9 +4152,7 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa
|
|||||||
}
|
}
|
||||||
if (message != null) {
|
if (message != null) {
|
||||||
if (message.type == 11) {
|
if (message.type == 11) {
|
||||||
NotificationCenter.getInstance().addToMemCache(51, message);
|
PhotoViewer.getInstance().openPhoto(message, ChatActivity.this);
|
||||||
Intent intent = new Intent(getParentActivity(), GalleryImageViewer.class);
|
|
||||||
getParentActivity().startActivity(intent);
|
|
||||||
} else if (message.type == 8 || message.type == 9) {
|
} else if (message.type == 8 || message.type == 9) {
|
||||||
File f = null;
|
File f = null;
|
||||||
String fileName = message.getFileName();
|
String fileName = message.getFileName();
|
||||||
|
@ -39,6 +39,7 @@ import org.telegram.messenger.NotificationCenter;
|
|||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
|
import org.telegram.objects.MessageObject;
|
||||||
import org.telegram.ui.Cells.ChatOrUserCell;
|
import org.telegram.ui.Cells.ChatOrUserCell;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
||||||
@ -51,7 +52,7 @@ import java.util.Collections;
|
|||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
public class ChatProfileActivity extends BaseFragment implements NotificationCenter.NotificationCenterDelegate, ContactsActivity.ContactsActivityDelegate {
|
public class ChatProfileActivity extends BaseFragment implements NotificationCenter.NotificationCenterDelegate, ContactsActivity.ContactsActivityDelegate, PhotoViewer.PhotoViewerProvider {
|
||||||
private ListView listView;
|
private ListView listView;
|
||||||
private ListAdapter listViewAdapter;
|
private ListAdapter listViewAdapter;
|
||||||
private int chat_id;
|
private int chat_id;
|
||||||
@ -90,7 +91,6 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.closeChats);
|
NotificationCenter.getInstance().addObserver(this, MessagesController.closeChats);
|
||||||
|
|
||||||
chat_id = getArguments().getInt("chat_id", 0);
|
chat_id = getArguments().getInt("chat_id", 0);
|
||||||
info = (TLRPC.ChatParticipants)NotificationCenter.getInstance().getFromMemCache(5);
|
|
||||||
updateOnlineCount();
|
updateOnlineCount();
|
||||||
MessagesController.getInstance().getMediaCount(-chat_id, classGuid, true);
|
MessagesController.getInstance().getMediaCount(-chat_id, classGuid, true);
|
||||||
avatarUpdater.delegate = new AvatarUpdater.AvatarUpdaterDelegate() {
|
avatarUpdater.delegate = new AvatarUpdater.AvatarUpdaterDelegate() {
|
||||||
@ -336,6 +336,37 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public PhotoViewer.PlaceProviderObject getPlaceForPhoto(MessageObject messageObject, TLRPC.FileLocation fileLocation) {
|
||||||
|
if (fileLocation == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
TLRPC.Chat chat = MessagesController.getInstance().chats.get(chat_id);
|
||||||
|
if (chat != null && chat.photo != null && chat.photo.photo_big != null) {
|
||||||
|
TLRPC.FileLocation photoBig = chat.photo.photo_big;
|
||||||
|
if (photoBig.local_id == fileLocation.local_id && photoBig.volume_id == fileLocation.volume_id && photoBig.dc_id == fileLocation.dc_id) {
|
||||||
|
int count = listView.getChildCount();
|
||||||
|
for (int a = 0; a < count; a++) {
|
||||||
|
View view = listView.getChildAt(a);
|
||||||
|
BackupImageView avatarImage = (BackupImageView)view.findViewById(R.id.settings_avatar_image);
|
||||||
|
if (avatarImage != null) {
|
||||||
|
int coords[] = new int[2];
|
||||||
|
avatarImage.getLocationInWindow(coords);
|
||||||
|
PhotoViewer.PlaceProviderObject object = new PhotoViewer.PlaceProviderObject();
|
||||||
|
object.viewX = coords[0];
|
||||||
|
object.viewY = coords[1] - Utilities.statusBarHeight;
|
||||||
|
object.parentView = listView;
|
||||||
|
object.imageReceiver = avatarImage.imageReceiver;
|
||||||
|
object.thumb = object.imageReceiver.getBitmap();
|
||||||
|
object.size = -1;
|
||||||
|
return object;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.updateInterfaces) {
|
if (id == MessagesController.updateInterfaces) {
|
||||||
int mask = (Integer)args[0];
|
int mask = (Integer)args[0];
|
||||||
@ -377,6 +408,10 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setChatInfo(TLRPC.ChatParticipants chatParticipants) {
|
||||||
|
info = chatParticipants;
|
||||||
|
}
|
||||||
|
|
||||||
private void updateVisibleRows(int mask) {
|
private void updateVisibleRows(int mask) {
|
||||||
if (listView == null) {
|
if (listView == null) {
|
||||||
return;
|
return;
|
||||||
@ -441,9 +476,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
if (action == 0) {
|
if (action == 0) {
|
||||||
TLRPC.Chat chat = MessagesController.getInstance().chats.get(chat_id);
|
TLRPC.Chat chat = MessagesController.getInstance().chats.get(chat_id);
|
||||||
if (chat.photo != null && chat.photo.photo_big != null) {
|
if (chat.photo != null && chat.photo.photo_big != null) {
|
||||||
NotificationCenter.getInstance().addToMemCache(53, chat.photo.photo_big);
|
PhotoViewer.getInstance().openPhoto(chat.photo.photo_big, this);
|
||||||
Intent intent = new Intent(getParentActivity(), GalleryImageViewer.class);
|
|
||||||
getParentActivity().startActivity(intent);
|
|
||||||
}
|
}
|
||||||
} else if (action == 1) {
|
} else if (action == 1) {
|
||||||
avatarUpdater.openCamera();
|
avatarUpdater.openCamera();
|
||||||
@ -606,10 +639,13 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
}
|
}
|
||||||
|
|
||||||
TLRPC.FileLocation photo = null;
|
TLRPC.FileLocation photo = null;
|
||||||
|
TLRPC.FileLocation photoBig = null;
|
||||||
if (chat.photo != null) {
|
if (chat.photo != null) {
|
||||||
photo = chat.photo.photo_small;
|
photo = chat.photo.photo_small;
|
||||||
|
photoBig = chat.photo.photo_big;
|
||||||
}
|
}
|
||||||
avatarImage.setImage(photo, "50_50", Utilities.getGroupAvatarForId(chat.id));
|
avatarImage.setImage(photo, "50_50", Utilities.getGroupAvatarForId(chat.id));
|
||||||
|
avatarImage.imageReceiver.setVisible(!PhotoViewer.getInstance().isShowingImage(photoBig), false);
|
||||||
return view;
|
return view;
|
||||||
} else if (type == 1) {
|
} else if (type == 1) {
|
||||||
if (view == null) {
|
if (view == null) {
|
||||||
|
@ -21,7 +21,6 @@ import android.view.View;
|
|||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.widget.AdapterView;
|
import android.widget.AdapterView;
|
||||||
import android.widget.BaseAdapter;
|
import android.widget.BaseAdapter;
|
||||||
import android.widget.ImageView;
|
|
||||||
import android.widget.ListView;
|
import android.widget.ListView;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
@ -423,12 +422,10 @@ public class DocumentSelectActivity extends BaseFragment {
|
|||||||
imageView.setImageBitmap(null);
|
imageView.setImageBitmap(null);
|
||||||
typeTextView.setText(item.ext.toUpperCase().substring(0, Math.min(item.ext.length(), 4)));
|
typeTextView.setText(item.ext.toUpperCase().substring(0, Math.min(item.ext.length(), 4)));
|
||||||
imageView.setImage(item.thumb, "55_42", 0);
|
imageView.setImage(item.thumb, "55_42", 0);
|
||||||
imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
|
|
||||||
imageView.setVisibility(View.VISIBLE);
|
imageView.setVisibility(View.VISIBLE);
|
||||||
typeTextView.setVisibility(View.VISIBLE);
|
typeTextView.setVisibility(View.VISIBLE);
|
||||||
} else if (item.icon != 0) {
|
} else if (item.icon != 0) {
|
||||||
imageView.setImageResource(item.icon);
|
imageView.setImageResource(item.icon);
|
||||||
imageView.setScaleType(ImageView.ScaleType.CENTER);
|
|
||||||
imageView.setVisibility(View.VISIBLE);
|
imageView.setVisibility(View.VISIBLE);
|
||||||
typeTextView.setVisibility(View.GONE);
|
typeTextView.setVisibility(View.GONE);
|
||||||
} else {
|
} else {
|
||||||
|
@ -103,7 +103,6 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
NotificationCenter.getInstance().addObserver(this, 701);
|
NotificationCenter.getInstance().addObserver(this, 701);
|
||||||
NotificationCenter.getInstance().addObserver(this, 702);
|
NotificationCenter.getInstance().addObserver(this, 702);
|
||||||
NotificationCenter.getInstance().addObserver(this, 703);
|
NotificationCenter.getInstance().addObserver(this, 703);
|
||||||
NotificationCenter.getInstance().addObserver(this, GalleryImageViewer.needShowAllMedia);
|
|
||||||
|
|
||||||
statusView = getLayoutInflater().inflate(R.layout.updating_state_layout, null);
|
statusView = getLayoutInflater().inflate(R.layout.updating_state_layout, null);
|
||||||
statusBackground = statusView.findViewById(R.id.back_button_background);
|
statusBackground = statusView.findViewById(R.id.back_button_background);
|
||||||
@ -601,7 +600,6 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
NotificationCenter.getInstance().removeObserver(this, 701);
|
NotificationCenter.getInstance().removeObserver(this, 701);
|
||||||
NotificationCenter.getInstance().removeObserver(this, 702);
|
NotificationCenter.getInstance().removeObserver(this, 702);
|
||||||
NotificationCenter.getInstance().removeObserver(this, 703);
|
NotificationCenter.getInstance().removeObserver(this, 703);
|
||||||
NotificationCenter.getInstance().removeObserver(this, GalleryImageViewer.needShowAllMedia);
|
|
||||||
if (notificationView != null) {
|
if (notificationView != null) {
|
||||||
notificationView.hide(false);
|
notificationView.hide(false);
|
||||||
notificationView.destroy();
|
notificationView.destroy();
|
||||||
@ -642,17 +640,13 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
startActivity(intent2);
|
startActivity(intent2);
|
||||||
onFinish();
|
onFinish();
|
||||||
finish();
|
finish();
|
||||||
} else if (id == GalleryImageViewer.needShowAllMedia) {
|
|
||||||
long dialog_id = (Long)args[0];
|
|
||||||
if (dialog_id != 0) {
|
|
||||||
Bundle args2 = new Bundle();
|
|
||||||
args2.putLong("dialog_id", dialog_id);
|
|
||||||
presentFragment(new MediaActivity(args2), false, true);
|
|
||||||
}
|
|
||||||
} else if (id == 658) {
|
} else if (id == 658) {
|
||||||
Integer push_user_id = (Integer)NotificationCenter.getInstance().getFromMemCache("push_user_id", 0);
|
if (PhotoViewer.getInstance().isVisible()) {
|
||||||
Integer push_chat_id = (Integer)NotificationCenter.getInstance().getFromMemCache("push_chat_id", 0);
|
PhotoViewer.getInstance().closePhoto(false);
|
||||||
Integer push_enc_id = (Integer)NotificationCenter.getInstance().getFromMemCache("push_enc_id", 0);
|
}
|
||||||
|
Integer push_chat_id = (Integer)args[0];
|
||||||
|
Integer push_user_id = (Integer)args[1];
|
||||||
|
Integer push_enc_id = (Integer)args[2];
|
||||||
|
|
||||||
if (push_user_id != 0) {
|
if (push_user_id != 0) {
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.closeChats);
|
NotificationCenter.getInstance().postNotificationName(MessagesController.closeChats);
|
||||||
@ -750,7 +744,7 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
@Override
|
@Override
|
||||||
public void onBackPressed() {
|
public void onBackPressed() {
|
||||||
if (PhotoViewer.getInstance().isVisible()) {
|
if (PhotoViewer.getInstance().isVisible()) {
|
||||||
PhotoViewer.getInstance().closePhoto();
|
PhotoViewer.getInstance().closePhoto(true);
|
||||||
} else {
|
} else {
|
||||||
super.onBackPressed();
|
super.onBackPressed();
|
||||||
}
|
}
|
||||||
@ -759,7 +753,7 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
@Override
|
@Override
|
||||||
public boolean onPreIme() {
|
public boolean onPreIme() {
|
||||||
if (PhotoViewer.getInstance().isVisible()) {
|
if (PhotoViewer.getInstance().isVisible()) {
|
||||||
PhotoViewer.getInstance().closePhoto();
|
PhotoViewer.getInstance().closePhoto(true);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return super.onPreIme();
|
return super.onPreIme();
|
||||||
|
@ -60,7 +60,6 @@ public class LocationActivity extends BaseFragment implements NotificationCenter
|
|||||||
@Override
|
@Override
|
||||||
public boolean onFragmentCreate() {
|
public boolean onFragmentCreate() {
|
||||||
super.onFragmentCreate();
|
super.onFragmentCreate();
|
||||||
messageObject = (MessageObject)NotificationCenter.getInstance().getFromMemCache(0);
|
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.closeChats);
|
NotificationCenter.getInstance().addObserver(this, MessagesController.closeChats);
|
||||||
if (messageObject != null) {
|
if (messageObject != null) {
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
||||||
@ -294,6 +293,10 @@ public class LocationActivity extends BaseFragment implements NotificationCenter
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setMessageObject(MessageObject message) {
|
||||||
|
messageObject = message;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.updateInterfaces) {
|
if (id == MessagesController.updateInterfaces) {
|
||||||
|
@ -10,7 +10,6 @@ package org.telegram.ui;
|
|||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
|
||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
@ -32,6 +31,7 @@ import org.telegram.objects.MessageObject;
|
|||||||
import org.telegram.messenger.MessagesController;
|
import org.telegram.messenger.MessagesController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.messenger.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
|
import org.telegram.objects.PhotoObject;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
import org.telegram.ui.Views.BackupImageView;
|
import org.telegram.ui.Views.BackupImageView;
|
||||||
import org.telegram.ui.Views.ActionBar.BaseFragment;
|
import org.telegram.ui.Views.ActionBar.BaseFragment;
|
||||||
@ -39,7 +39,7 @@ import org.telegram.ui.Views.ActionBar.BaseFragment;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
public class MediaActivity extends BaseFragment implements NotificationCenter.NotificationCenterDelegate {
|
public class MediaActivity extends BaseFragment implements NotificationCenter.NotificationCenterDelegate, PhotoViewer.PhotoViewerProvider {
|
||||||
private GridView listView;
|
private GridView listView;
|
||||||
private ListAdapter listAdapter;
|
private ListAdapter listAdapter;
|
||||||
private ArrayList<MessageObject> messages = new ArrayList<MessageObject>();
|
private ArrayList<MessageObject> messages = new ArrayList<MessageObject>();
|
||||||
@ -114,10 +114,7 @@ public class MediaActivity extends BaseFragment implements NotificationCenter.No
|
|||||||
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
|
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
|
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
|
||||||
NotificationCenter.getInstance().addToMemCache(54, messages);
|
PhotoViewer.getInstance().openPhoto(messages, i, MediaActivity.this);
|
||||||
NotificationCenter.getInstance().addToMemCache(55, i);
|
|
||||||
Intent intent = new Intent(getParentActivity(), GalleryImageViewer.class);
|
|
||||||
getParentActivity().startActivity(intent);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
if (loading && messages.isEmpty()) {
|
if (loading && messages.isEmpty()) {
|
||||||
@ -266,6 +263,41 @@ public class MediaActivity extends BaseFragment implements NotificationCenter.No
|
|||||||
fixLayout();
|
fixLayout();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public PhotoViewer.PlaceProviderObject getPlaceForPhoto(MessageObject messageObject, TLRPC.FileLocation fileLocation) {
|
||||||
|
if (messageObject == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
int count = listView.getChildCount();
|
||||||
|
|
||||||
|
for (int a = 0; a < count; a++) {
|
||||||
|
View view = listView.getChildAt(a);
|
||||||
|
BackupImageView imageView = (BackupImageView)view.findViewById(R.id.media_photo_image);
|
||||||
|
if (imageView != null) {
|
||||||
|
int num = (Integer)imageView.getTag();
|
||||||
|
if (num < 0 || num >= messages.size()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
MessageObject message = messages.get(num);
|
||||||
|
if (message != null && message.messageOwner.id == messageObject.messageOwner.id) {
|
||||||
|
int coords[] = new int[2];
|
||||||
|
imageView.getLocationInWindow(coords);
|
||||||
|
PhotoViewer.PlaceProviderObject object = new PhotoViewer.PlaceProviderObject();
|
||||||
|
object.viewX = coords[0];
|
||||||
|
object.viewY = coords[1] - Utilities.statusBarHeight;
|
||||||
|
object.parentView = listView;
|
||||||
|
object.imageReceiver = imageView.imageReceiver;
|
||||||
|
object.thumb = object.imageReceiver.getBitmap();
|
||||||
|
return object;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
// NotificationCenter.getInstance().addToMemCache(54, messages); TODO
|
||||||
|
// NotificationCenter.getInstance().addToMemCache(55, i);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
private void fixLayout() {
|
private void fixLayout() {
|
||||||
if (listView != null) {
|
if (listView != null) {
|
||||||
ViewTreeObserver obs = listView.getViewTreeObserver();
|
ViewTreeObserver obs = listView.getViewTreeObserver();
|
||||||
@ -351,20 +383,20 @@ public class MediaActivity extends BaseFragment implements NotificationCenter.No
|
|||||||
view.setLayoutParams(params);
|
view.setLayoutParams(params);
|
||||||
|
|
||||||
BackupImageView imageView = (BackupImageView)view.findViewById(R.id.media_photo_image);
|
BackupImageView imageView = (BackupImageView)view.findViewById(R.id.media_photo_image);
|
||||||
|
imageView.setTag(i);
|
||||||
|
|
||||||
if (message.messageOwner.media != null && message.messageOwner.media.photo != null && !message.messageOwner.media.photo.sizes.isEmpty()) {
|
if (message.messageOwner.media != null && message.messageOwner.media.photo != null && !message.messageOwner.media.photo.sizes.isEmpty()) {
|
||||||
ArrayList<TLRPC.PhotoSize> sizes = message.messageOwner.media.photo.sizes;
|
ArrayList<TLRPC.PhotoSize> sizes = message.messageOwner.media.photo.sizes;
|
||||||
boolean set = false;
|
if (message.imagePreview != null) {
|
||||||
if (!set) {
|
imageView.setImageBitmap(message.imagePreview);
|
||||||
if (message.imagePreview != null) {
|
} else {
|
||||||
imageView.setImageBitmap(message.imagePreview);
|
TLRPC.PhotoSize photoSize = PhotoObject.getClosestPhotoSizeWithSize(message.messageOwner.media.photo.sizes, 80, 80);
|
||||||
} else {
|
imageView.setImage(photoSize.location, null, R.drawable.photo_placeholder_in);
|
||||||
imageView.setImage(message.messageOwner.media.photo.sizes.get(0).location, null, R.drawable.photo_placeholder_in);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
imageView.setImageResource(R.drawable.photo_placeholder_in);
|
imageView.setImageResource(R.drawable.photo_placeholder_in);
|
||||||
}
|
}
|
||||||
|
imageView.imageReceiver.setVisible(!PhotoViewer.getInstance().isShowingImage(message), false);
|
||||||
} else if (type == 1) {
|
} else if (type == 1) {
|
||||||
MessageObject message = messages.get(i);
|
MessageObject message = messages.get(i);
|
||||||
if (view == null) {
|
if (view == null) {
|
||||||
@ -378,6 +410,7 @@ public class MediaActivity extends BaseFragment implements NotificationCenter.No
|
|||||||
|
|
||||||
TextView textView = (TextView)view.findViewById(R.id.chat_video_time);
|
TextView textView = (TextView)view.findViewById(R.id.chat_video_time);
|
||||||
BackupImageView imageView = (BackupImageView)view.findViewById(R.id.media_photo_image);
|
BackupImageView imageView = (BackupImageView)view.findViewById(R.id.media_photo_image);
|
||||||
|
imageView.setTag(i);
|
||||||
|
|
||||||
if (message.messageOwner.media.video != null && message.messageOwner.media.video.thumb != null) {
|
if (message.messageOwner.media.video != null && message.messageOwner.media.video.thumb != null) {
|
||||||
int duration = message.messageOwner.media.video.duration;
|
int duration = message.messageOwner.media.video.duration;
|
||||||
@ -394,6 +427,7 @@ public class MediaActivity extends BaseFragment implements NotificationCenter.No
|
|||||||
textView.setVisibility(View.GONE);
|
textView.setVisibility(View.GONE);
|
||||||
imageView.setImageResource(R.drawable.photo_placeholder_in);
|
imageView.setImageResource(R.drawable.photo_placeholder_in);
|
||||||
}
|
}
|
||||||
|
imageView.imageReceiver.setVisible(!PhotoViewer.getInstance().isShowingImage(message), false);
|
||||||
} else if (type == 2) {
|
} else if (type == 2) {
|
||||||
if (view == null) {
|
if (view == null) {
|
||||||
LayoutInflater li = (LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
LayoutInflater li = (LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
||||||
|
@ -51,6 +51,7 @@ import org.telegram.messenger.R;
|
|||||||
import org.telegram.messenger.RPCRequest;
|
import org.telegram.messenger.RPCRequest;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
|
import org.telegram.objects.MessageObject;
|
||||||
import org.telegram.objects.PhotoObject;
|
import org.telegram.objects.PhotoObject;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
import org.telegram.ui.Views.AvatarUpdater;
|
import org.telegram.ui.Views.AvatarUpdater;
|
||||||
@ -61,7 +62,7 @@ import java.io.File;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|
||||||
public class SettingsActivity extends BaseFragment implements NotificationCenter.NotificationCenterDelegate {
|
public class SettingsActivity extends BaseFragment implements NotificationCenter.NotificationCenterDelegate, PhotoViewer.PhotoViewerProvider {
|
||||||
private ListView listView;
|
private ListView listView;
|
||||||
private ListAdapter listAdapter;
|
private ListAdapter listAdapter;
|
||||||
private AvatarUpdater avatarUpdater = new AvatarUpdater();
|
private AvatarUpdater avatarUpdater = new AvatarUpdater();
|
||||||
@ -411,6 +412,38 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
return fragmentView;
|
return fragmentView;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public PhotoViewer.PlaceProviderObject getPlaceForPhoto(MessageObject messageObject, TLRPC.FileLocation fileLocation) {
|
||||||
|
if (fileLocation == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
TLRPC.User user = MessagesController.getInstance().users.get(UserConfig.clientUserId);
|
||||||
|
if (user != null && user.photo != null && user.photo.photo_big != null) {
|
||||||
|
TLRPC.FileLocation photoBig = user.photo.photo_big;
|
||||||
|
if (photoBig.local_id == fileLocation.local_id && photoBig.volume_id == fileLocation.volume_id && photoBig.dc_id == fileLocation.dc_id) {
|
||||||
|
int count = listView.getChildCount();
|
||||||
|
for (int a = 0; a < count; a++) {
|
||||||
|
View view = listView.getChildAt(a);
|
||||||
|
BackupImageView avatarImage = (BackupImageView)view.findViewById(R.id.settings_avatar_image);
|
||||||
|
if (avatarImage != null) {
|
||||||
|
int coords[] = new int[2];
|
||||||
|
avatarImage.getLocationInWindow(coords);
|
||||||
|
PhotoViewer.PlaceProviderObject object = new PhotoViewer.PlaceProviderObject();
|
||||||
|
object.viewX = coords[0];
|
||||||
|
object.viewY = coords[1] - Utilities.statusBarHeight;
|
||||||
|
object.parentView = listView;
|
||||||
|
object.imageReceiver = avatarImage.imageReceiver;
|
||||||
|
object.user_id = UserConfig.clientUserId;
|
||||||
|
object.thumb = object.imageReceiver.getBitmap();
|
||||||
|
object.size = -1;
|
||||||
|
return object;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
public void performAskAQuestion() {
|
public void performAskAQuestion() {
|
||||||
final SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
final SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
||||||
int uid = preferences.getInt("support_id", 0);
|
int uid = preferences.getInt("support_id", 0);
|
||||||
@ -638,10 +671,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
if (i == 0 && full) {
|
if (i == 0 && full) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(UserConfig.clientUserId);
|
TLRPC.User user = MessagesController.getInstance().users.get(UserConfig.clientUserId);
|
||||||
if (user != null && user.photo != null && user.photo.photo_big != null) {
|
if (user != null && user.photo != null && user.photo.photo_big != null) {
|
||||||
NotificationCenter.getInstance().addToMemCache(56, user.id);
|
PhotoViewer.getInstance().openPhoto(user.photo.photo_big, SettingsActivity.this);
|
||||||
NotificationCenter.getInstance().addToMemCache(53, user.photo.photo_big);
|
|
||||||
Intent intent = new Intent(getParentActivity(), GalleryImageViewer.class);
|
|
||||||
getParentActivity().startActivity(intent);
|
|
||||||
}
|
}
|
||||||
} else if (i == 0 && !full || i == 1 && full) {
|
} else if (i == 0 && !full || i == 1 && full) {
|
||||||
avatarUpdater.openCamera();
|
avatarUpdater.openCamera();
|
||||||
@ -714,10 +744,13 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
BackupImageView avatarImage = (BackupImageView)view.findViewById(R.id.settings_avatar_image);
|
BackupImageView avatarImage = (BackupImageView)view.findViewById(R.id.settings_avatar_image);
|
||||||
avatarImage.processDetach = false;
|
avatarImage.processDetach = false;
|
||||||
TLRPC.FileLocation photo = null;
|
TLRPC.FileLocation photo = null;
|
||||||
|
TLRPC.FileLocation photoBig = null;
|
||||||
if (user.photo != null) {
|
if (user.photo != null) {
|
||||||
photo = user.photo.photo_small;
|
photo = user.photo.photo_small;
|
||||||
|
photoBig = user.photo.photo_big;
|
||||||
}
|
}
|
||||||
avatarImage.setImage(photo, null, Utilities.getUserAvatarForId(user.id));
|
avatarImage.setImage(photo, "50_50", Utilities.getUserAvatarForId(user.id));
|
||||||
|
avatarImage.imageReceiver.setVisible(!PhotoViewer.getInstance().isShowingImage(photoBig), false);
|
||||||
}
|
}
|
||||||
return view;
|
return view;
|
||||||
} else if (type == 1) {
|
} else if (type == 1) {
|
||||||
|
@ -184,10 +184,8 @@ public class SettingsBlockedUsers extends BaseFragment implements NotificationCe
|
|||||||
if (progressView != null) {
|
if (progressView != null) {
|
||||||
progressView.setVisibility(View.GONE);
|
progressView.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
if (listView != null) {
|
if (listView != null && listView.getEmptyView() == null) {
|
||||||
if (listView.getEmptyView() == null) {
|
listView.setEmptyView(emptyView);
|
||||||
listView.setEmptyView(emptyView);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (listViewAdapter != null) {
|
if (listViewAdapter != null) {
|
||||||
listViewAdapter.notifyDataSetChanged();
|
listViewAdapter.notifyDataSetChanged();
|
||||||
@ -212,10 +210,8 @@ public class SettingsBlockedUsers extends BaseFragment implements NotificationCe
|
|||||||
if (progressView != null) {
|
if (progressView != null) {
|
||||||
progressView.setVisibility(View.GONE);
|
progressView.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
if (listView != null) {
|
if (listView != null && listView.getEmptyView() == null) {
|
||||||
if (listView.getEmptyView() == null) {
|
listView.setEmptyView(emptyView);
|
||||||
listView.setEmptyView(emptyView);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (listViewAdapter != null) {
|
if (listViewAdapter != null) {
|
||||||
listViewAdapter.notifyDataSetChanged();
|
listViewAdapter.notifyDataSetChanged();
|
||||||
|
@ -212,9 +212,13 @@ public class SettingsNotificationsActivity extends BaseFragment {
|
|||||||
SharedPreferences.Editor editor = preferences.edit();
|
SharedPreferences.Editor editor = preferences.edit();
|
||||||
editor.clear();
|
editor.clear();
|
||||||
editor.commit();
|
editor.commit();
|
||||||
listView.invalidateViews();
|
if (listView != null) {
|
||||||
Toast toast = Toast.makeText(getParentActivity(), R.string.ResetNotificationsText, Toast.LENGTH_SHORT);
|
listView.invalidateViews();
|
||||||
toast.show();
|
}
|
||||||
|
if (getParentActivity() != null) {
|
||||||
|
Toast toast = Toast.makeText(getParentActivity(), R.string.ResetNotificationsText, Toast.LENGTH_SHORT);
|
||||||
|
toast.show();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -42,6 +42,7 @@ import org.telegram.messenger.NotificationCenter;
|
|||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.RPCRequest;
|
import org.telegram.messenger.RPCRequest;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
|
import org.telegram.objects.MessageObject;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarMenuItem;
|
import org.telegram.ui.Views.ActionBar.ActionBarMenuItem;
|
||||||
@ -51,7 +52,7 @@ import org.telegram.ui.Views.IdenticonView;
|
|||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
public class UserProfileActivity extends BaseFragment implements NotificationCenter.NotificationCenterDelegate, MessagesActivity.MessagesActivityDelegate {
|
public class UserProfileActivity extends BaseFragment implements NotificationCenter.NotificationCenterDelegate, MessagesActivity.MessagesActivityDelegate, PhotoViewer.PhotoViewerProvider {
|
||||||
private ListView listView;
|
private ListView listView;
|
||||||
private ListAdapter listAdapter;
|
private ListAdapter listAdapter;
|
||||||
private int user_id;
|
private int user_id;
|
||||||
@ -452,6 +453,38 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public PhotoViewer.PlaceProviderObject getPlaceForPhoto(MessageObject messageObject, TLRPC.FileLocation fileLocation) {
|
||||||
|
if (fileLocation == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
||||||
|
if (user != null && user.photo != null && user.photo.photo_big != null) {
|
||||||
|
TLRPC.FileLocation photoBig = user.photo.photo_big;
|
||||||
|
if (photoBig.local_id == fileLocation.local_id && photoBig.volume_id == fileLocation.volume_id && photoBig.dc_id == fileLocation.dc_id) {
|
||||||
|
int count = listView.getChildCount();
|
||||||
|
for (int a = 0; a < count; a++) {
|
||||||
|
View view = listView.getChildAt(a);
|
||||||
|
BackupImageView avatarImage = (BackupImageView)view.findViewById(R.id.settings_avatar_image);
|
||||||
|
if (avatarImage != null) {
|
||||||
|
int coords[] = new int[2];
|
||||||
|
avatarImage.getLocationInWindow(coords);
|
||||||
|
PhotoViewer.PlaceProviderObject object = new PhotoViewer.PlaceProviderObject();
|
||||||
|
object.viewX = coords[0];
|
||||||
|
object.viewY = coords[1] - Utilities.statusBarHeight;
|
||||||
|
object.parentView = listView;
|
||||||
|
object.imageReceiver = avatarImage.imageReceiver;
|
||||||
|
object.user_id = user_id;
|
||||||
|
object.thumb = object.imageReceiver.getBitmap();
|
||||||
|
object.size = -1;
|
||||||
|
return object;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
private void createActionBarMenu() {
|
private void createActionBarMenu() {
|
||||||
ActionBarMenu menu = actionBarLayer.createMenu();
|
ActionBarMenu menu = actionBarLayer.createMenu();
|
||||||
menu.clearItems();
|
menu.clearItems();
|
||||||
@ -557,10 +590,7 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
public void onClick(View view) {
|
public void onClick(View view) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
||||||
if (user.photo != null && user.photo.photo_big != null) {
|
if (user.photo != null && user.photo.photo_big != null) {
|
||||||
NotificationCenter.getInstance().addToMemCache(56, user_id);
|
PhotoViewer.getInstance().openPhoto(user.photo.photo_big, UserProfileActivity.this);
|
||||||
NotificationCenter.getInstance().addToMemCache(53, user.photo.photo_big);
|
|
||||||
Intent intent = new Intent(getParentActivity(), GalleryImageViewer.class);
|
|
||||||
getParentActivity().startActivity(intent);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -576,10 +606,13 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
onlineText.setText(LocaleController.formatUserStatus(user));
|
onlineText.setText(LocaleController.formatUserStatus(user));
|
||||||
|
|
||||||
TLRPC.FileLocation photo = null;
|
TLRPC.FileLocation photo = null;
|
||||||
|
TLRPC.FileLocation photoBig = null;
|
||||||
if (user.photo != null) {
|
if (user.photo != null) {
|
||||||
photo = user.photo.photo_small;
|
photo = user.photo.photo_small;
|
||||||
|
photoBig = user.photo.photo_big;
|
||||||
}
|
}
|
||||||
avatarImage.setImage(photo, "50_50", Utilities.getUserAvatarForId(user.id));
|
avatarImage.setImage(photo, "50_50", Utilities.getUserAvatarForId(user.id));
|
||||||
|
avatarImage.imageReceiver.setVisible(!PhotoViewer.getInstance().isShowingImage(photoBig), false);
|
||||||
return view;
|
return view;
|
||||||
} else if (type == 1) {
|
} else if (type == 1) {
|
||||||
if (view == null) {
|
if (view == null) {
|
||||||
|
@ -1,16 +0,0 @@
|
|||||||
/*
|
|
||||||
* This is the source code of Telegram for Android v. 1.3.2.
|
|
||||||
* It is licensed under GNU GPL v. 2 or later.
|
|
||||||
* You should have received a copy of the license in this archive (see LICENSE).
|
|
||||||
*
|
|
||||||
* Copyright Nikolai Kudashov, 2013.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package org.telegram.ui.Views;
|
|
||||||
|
|
||||||
import org.telegram.objects.MessageObject;
|
|
||||||
|
|
||||||
public abstract class AbstractGalleryActivity extends PausableActivity {
|
|
||||||
public abstract void topBtn();
|
|
||||||
public abstract void didShowMessageObject(MessageObject obj);
|
|
||||||
}
|
|
@ -111,12 +111,13 @@ public class ActionBar extends FrameLayout {
|
|||||||
currentLayer.setBackLayoutVisible(currentLayer.isSearchFieldVisible || currentBackOverlay == null ? VISIBLE : INVISIBLE);
|
currentLayer.setBackLayoutVisible(currentLayer.isSearchFieldVisible || currentBackOverlay == null ? VISIBLE : INVISIBLE);
|
||||||
}
|
}
|
||||||
if (currentBackOverlay != null) {
|
if (currentBackOverlay != null) {
|
||||||
currentBackOverlay.setVisibility(currentLayer.isSearchFieldVisible ? GONE : VISIBLE);
|
|
||||||
ViewGroup.LayoutParams layoutParams = currentBackOverlay.getLayoutParams();
|
ViewGroup.LayoutParams layoutParams = currentBackOverlay.getLayoutParams();
|
||||||
if (currentLayer != null) {
|
if (currentLayer != null) {
|
||||||
|
currentBackOverlay.setVisibility(currentLayer.isSearchFieldVisible ? GONE : VISIBLE);
|
||||||
currentLayer.measure(widthMeasureSpec, heightMeasureSpec);
|
currentLayer.measure(widthMeasureSpec, heightMeasureSpec);
|
||||||
layoutParams.width = Math.min(currentBackOverlayWidth, currentLayer.getBackLayoutWidth());
|
layoutParams.width = Math.min(currentBackOverlayWidth, currentLayer.getBackLayoutWidth());
|
||||||
} else {
|
} else {
|
||||||
|
currentBackOverlay.setVisibility(VISIBLE);
|
||||||
layoutParams.width = LayoutParams.WRAP_CONTENT;
|
layoutParams.width = LayoutParams.WRAP_CONTENT;
|
||||||
}
|
}
|
||||||
if (layoutParams.width != 0) {
|
if (layoutParams.width != 0) {
|
||||||
|
@ -13,7 +13,6 @@ import android.animation.AnimatorSet;
|
|||||||
import android.animation.ObjectAnimator;
|
import android.animation.ObjectAnimator;
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.pm.ActivityInfo;
|
|
||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
@ -21,7 +20,6 @@ import android.view.ActionMode;
|
|||||||
import android.view.Gravity;
|
import android.view.Gravity;
|
||||||
import android.view.KeyEvent;
|
import android.view.KeyEvent;
|
||||||
import android.view.MotionEvent;
|
import android.view.MotionEvent;
|
||||||
import android.view.Surface;
|
|
||||||
import android.view.VelocityTracker;
|
import android.view.VelocityTracker;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
@ -51,7 +49,6 @@ public class ActionBarActivity extends Activity {
|
|||||||
private boolean maybeStartTracking = false;
|
private boolean maybeStartTracking = false;
|
||||||
protected boolean startedTracking = false;
|
protected boolean startedTracking = false;
|
||||||
private int startedTrackingX;
|
private int startedTrackingX;
|
||||||
private int prevOrientation = -10;
|
|
||||||
protected boolean animationInProgress = false;
|
protected boolean animationInProgress = false;
|
||||||
private VelocityTracker velocityTracker = null;
|
private VelocityTracker velocityTracker = null;
|
||||||
private boolean beginTrackingSent = false;
|
private boolean beginTrackingSent = false;
|
||||||
@ -206,14 +203,7 @@ public class ActionBarActivity extends Activity {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
containerViewBack.setVisibility(View.GONE);
|
containerViewBack.setVisibility(View.GONE);
|
||||||
try {
|
Utilities.unlockOrientation(this);
|
||||||
if (prevOrientation != -10) {
|
|
||||||
setRequestedOrientation(prevOrientation);
|
|
||||||
prevOrientation = -10;
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
}
|
|
||||||
startedTracking = false;
|
startedTracking = false;
|
||||||
animationInProgress = false;
|
animationInProgress = false;
|
||||||
}
|
}
|
||||||
@ -244,30 +234,7 @@ public class ActionBarActivity extends Activity {
|
|||||||
}
|
}
|
||||||
lastFragment.onResume();
|
lastFragment.onResume();
|
||||||
|
|
||||||
try {
|
Utilities.lockOrientation(this);
|
||||||
prevOrientation = getRequestedOrientation();
|
|
||||||
WindowManager manager = (WindowManager)getSystemService(Activity.WINDOW_SERVICE);
|
|
||||||
if (manager != null && manager.getDefaultDisplay() != null) {
|
|
||||||
int rotation = manager.getDefaultDisplay().getRotation();
|
|
||||||
if (rotation == Surface.ROTATION_270) {
|
|
||||||
if (Build.VERSION.SDK_INT >= 9) {
|
|
||||||
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_REVERSE_LANDSCAPE);
|
|
||||||
} else {
|
|
||||||
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
|
|
||||||
}
|
|
||||||
} else if (rotation == Surface.ROTATION_90) {
|
|
||||||
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
|
|
||||||
} else if (rotation == Surface.ROTATION_0) {
|
|
||||||
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
|
|
||||||
} else {
|
|
||||||
if (Build.VERSION.SDK_INT >= 9) {
|
|
||||||
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_REVERSE_PORTRAIT);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean onTouchEvent(MotionEvent ev) {
|
public boolean onTouchEvent(MotionEvent ev) {
|
||||||
|
@ -26,8 +26,14 @@ import org.telegram.messenger.Utilities;
|
|||||||
|
|
||||||
public class ActionBarLayer extends FrameLayout {
|
public class ActionBarLayer extends FrameLayout {
|
||||||
|
|
||||||
public interface ActionBarMenuOnItemClick {
|
public static class ActionBarMenuOnItemClick {
|
||||||
public abstract void onItemClick(int id);
|
public void onItemClick(int id) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean canOpenMenu() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private FrameLayout backButtonFrameLayout;
|
private FrameLayout backButtonFrameLayout;
|
||||||
|
@ -75,7 +75,9 @@ public class ActionBarMenu extends LinearLayout {
|
|||||||
public void onClick(View view) {
|
public void onClick(View view) {
|
||||||
ActionBarMenuItem item = (ActionBarMenuItem)view;
|
ActionBarMenuItem item = (ActionBarMenuItem)view;
|
||||||
if (item.hasSubMenu()) {
|
if (item.hasSubMenu()) {
|
||||||
item.toggleSubMenu();
|
if (parentActionBarLayer.actionBarMenuOnItemClick.canOpenMenu()) {
|
||||||
|
item.toggleSubMenu();
|
||||||
|
}
|
||||||
} else if (item.isSearchField()) {
|
} else if (item.isSearchField()) {
|
||||||
parentActionBarLayer.onSearchFieldVisibilityChanged(item.toggleSearch());
|
parentActionBarLayer.onSearchFieldVisibilityChanged(item.toggleSearch());
|
||||||
} else {
|
} else {
|
||||||
|
@ -79,6 +79,7 @@ public class ActionBarMenuItem extends ImageView {
|
|||||||
layoutParams.width = Utilities.dp(196);
|
layoutParams.width = Utilities.dp(196);
|
||||||
layoutParams.height = Utilities.density >= 3 ? 2 : 1;
|
layoutParams.height = Utilities.density >= 3 ? 2 : 1;
|
||||||
delimeter.setLayoutParams(layoutParams);
|
delimeter.setLayoutParams(layoutParams);
|
||||||
|
delimeter.setTag(100 + id);
|
||||||
}
|
}
|
||||||
TextView textView = new TextView(getContext());
|
TextView textView = new TextView(getContext());
|
||||||
textView.setTextColor(0xff000000);
|
textView.setTextColor(0xff000000);
|
||||||
@ -255,4 +256,26 @@ public class ActionBarMenuItem extends ImageView {
|
|||||||
popupWindow.update(this, parentActionBar.getMeasuredWidth() - popupLayout.getMeasuredWidth() - getLeft() - parentMenu.getLeft(), 0, -1, -1);
|
popupWindow.update(this, parentActionBar.getMeasuredWidth() - popupLayout.getMeasuredWidth() - getLeft() - parentMenu.getLeft(), 0, -1, -1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void hideSubItem(int id) {
|
||||||
|
View view = popupLayout.findViewWithTag(id);
|
||||||
|
if (view != null) {
|
||||||
|
view.setVisibility(GONE);
|
||||||
|
}
|
||||||
|
view = popupLayout.findViewWithTag(100 + id);
|
||||||
|
if (view != null) {
|
||||||
|
view.setVisibility(GONE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void showSubItem(int id) {
|
||||||
|
View view = popupLayout.findViewWithTag(id);
|
||||||
|
if (view != null) {
|
||||||
|
view.setVisibility(VISIBLE);
|
||||||
|
}
|
||||||
|
view = popupLayout.findViewWithTag(100 + id);
|
||||||
|
if (view != null) {
|
||||||
|
view.setVisibility(VISIBLE);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -8,43 +8,40 @@
|
|||||||
|
|
||||||
package org.telegram.ui.Views;
|
package org.telegram.ui.Views;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
import android.graphics.Bitmap;
|
import android.graphics.Bitmap;
|
||||||
import android.graphics.Canvas;
|
import android.graphics.Canvas;
|
||||||
import android.graphics.drawable.BitmapDrawable;
|
import android.graphics.drawable.BitmapDrawable;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
import android.graphics.drawable.NinePatchDrawable;
|
import android.util.AttributeSet;
|
||||||
import android.os.Build;
|
import android.view.View;
|
||||||
import android.widget.ImageView;
|
|
||||||
|
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.FileLoader;
|
|
||||||
import org.telegram.messenger.FileLog;
|
|
||||||
import org.telegram.messenger.Utilities;
|
|
||||||
|
|
||||||
public class BackupImageView extends ImageView {
|
import java.lang.ref.WeakReference;
|
||||||
boolean makeRequest = true;
|
|
||||||
public String currentPath;
|
public class BackupImageView extends View {
|
||||||
|
public ImageReceiver imageReceiver;
|
||||||
public boolean processDetach = true;
|
public boolean processDetach = true;
|
||||||
private boolean isPlaceholder;
|
|
||||||
private boolean ignoreLayout = true;
|
|
||||||
|
|
||||||
TLRPC.FileLocation last_path;
|
public BackupImageView(Context context) {
|
||||||
String last_httpUrl;
|
|
||||||
String last_filter;
|
|
||||||
int last_placeholder;
|
|
||||||
Bitmap last_placeholderBitmap;
|
|
||||||
int last_size;
|
|
||||||
|
|
||||||
public BackupImageView(android.content.Context context) {
|
|
||||||
super(context);
|
super(context);
|
||||||
|
init();
|
||||||
}
|
}
|
||||||
|
|
||||||
public BackupImageView(android.content.Context context, android.util.AttributeSet attrs) {
|
public BackupImageView(Context context, AttributeSet attrs) {
|
||||||
super(context, attrs);
|
super(context, attrs);
|
||||||
|
init();
|
||||||
}
|
}
|
||||||
|
|
||||||
public BackupImageView(android.content.Context context, android.util.AttributeSet attrs, int defStyle) {
|
public BackupImageView(Context context, AttributeSet attrs, int defStyleAttr) {
|
||||||
super(context, attrs, defStyle);
|
super(context, attrs, defStyleAttr);
|
||||||
|
init();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void init() {
|
||||||
|
imageReceiver = new ImageReceiver();
|
||||||
|
imageReceiver.parentView = new WeakReference<View>(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setImage(TLRPC.FileLocation path, String filter, int placeholder) {
|
public void setImage(TLRPC.FileLocation path, String filter, int placeholder) {
|
||||||
@ -68,135 +65,42 @@ public class BackupImageView extends ImageView {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void setImage(TLRPC.FileLocation path, String httpUrl, String filter, int placeholder, Bitmap placeholderBitmap, int size) {
|
public void setImage(TLRPC.FileLocation path, String httpUrl, String filter, int placeholder, Bitmap placeholderBitmap, int size) {
|
||||||
if ((path == null && httpUrl == null) || (path != null && !(path instanceof TLRPC.TL_fileLocation) && !(path instanceof TLRPC.TL_fileEncryptedLocation))) {
|
Drawable placeholderDrawable = null;
|
||||||
recycleBitmap(null);
|
if (placeholderBitmap != null) {
|
||||||
currentPath = null;
|
placeholderDrawable = new BitmapDrawable(null, placeholderBitmap);
|
||||||
isPlaceholder = true;
|
} else if (placeholder != 0) {
|
||||||
|
placeholderDrawable = getResources().getDrawable(placeholder);
|
||||||
last_path = null;
|
|
||||||
last_httpUrl = null;
|
|
||||||
last_filter = null;
|
|
||||||
last_placeholder = 0;
|
|
||||||
last_size = 0;
|
|
||||||
last_placeholderBitmap = null;
|
|
||||||
|
|
||||||
FileLoader.getInstance().cancelLoadingForImageView(this);
|
|
||||||
if (placeholder != 0) {
|
|
||||||
setImageResourceMy(placeholder);
|
|
||||||
} else if (placeholderBitmap != null) {
|
|
||||||
setImageBitmapMy(placeholderBitmap);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
String key;
|
|
||||||
if (path != null) {
|
|
||||||
key = path.volume_id + "_" + path.local_id;
|
|
||||||
} else {
|
|
||||||
key = Utilities.MD5(httpUrl);
|
|
||||||
}
|
|
||||||
if (filter != null) {
|
|
||||||
key += "@" + filter;
|
|
||||||
}
|
|
||||||
Bitmap img;
|
|
||||||
if (currentPath != null) {
|
|
||||||
if (currentPath.equals(key)) {
|
|
||||||
return;
|
|
||||||
} else {
|
|
||||||
img = FileLoader.getInstance().getImageFromMemory(path, httpUrl, this, filter, true);
|
|
||||||
recycleBitmap(img);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
img = FileLoader.getInstance().getImageFromMemory(path, httpUrl, this, filter, true);
|
|
||||||
}
|
|
||||||
currentPath = key;
|
|
||||||
last_path = path;
|
|
||||||
last_httpUrl = httpUrl;
|
|
||||||
last_filter = filter;
|
|
||||||
last_placeholder = placeholder;
|
|
||||||
last_placeholderBitmap = placeholderBitmap;
|
|
||||||
last_size = size;
|
|
||||||
if (img == null) {
|
|
||||||
isPlaceholder = true;
|
|
||||||
if (placeholder != 0) {
|
|
||||||
setImageResourceMy(placeholder);
|
|
||||||
} else if (placeholderBitmap != null) {
|
|
||||||
setImageBitmapMy(placeholderBitmap);
|
|
||||||
}
|
|
||||||
FileLoader.getInstance().loadImage(path, httpUrl, this, filter, true, size);
|
|
||||||
} else {
|
|
||||||
setImageBitmap(img, currentPath);
|
|
||||||
}
|
}
|
||||||
|
imageReceiver.setImage(path, httpUrl, filter, placeholderDrawable, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setImageBitmap(Bitmap bitmap, String imgKey) {
|
public void setImageBitmap(Bitmap bitmap) {
|
||||||
if (currentPath == null || !imgKey.equals(currentPath)) {
|
imageReceiver.setImageBitmap(bitmap);
|
||||||
return;
|
|
||||||
}
|
|
||||||
isPlaceholder = false;
|
|
||||||
FileLoader.getInstance().incrementUseCount(currentPath);
|
|
||||||
if (ignoreLayout) {
|
|
||||||
makeRequest = false;
|
|
||||||
}
|
|
||||||
super.setImageBitmap(bitmap);
|
|
||||||
if (ignoreLayout) {
|
|
||||||
makeRequest = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void clearImage() {
|
public void setImageResource(int resId) {
|
||||||
recycleBitmap(null);
|
imageReceiver.setImageBitmap(getResources().getDrawable(resId));
|
||||||
}
|
|
||||||
|
|
||||||
private void recycleBitmap(Bitmap newBitmap) {
|
|
||||||
Drawable drawable = getDrawable();
|
|
||||||
if (drawable == null || isPlaceholder) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (drawable instanceof BitmapDrawable) {
|
|
||||||
Bitmap bitmap = ((BitmapDrawable)drawable).getBitmap();
|
|
||||||
if (bitmap != null && bitmap != newBitmap) {
|
|
||||||
if (currentPath != null) {
|
|
||||||
boolean canDelete = FileLoader.getInstance().decrementUseCount(currentPath);
|
|
||||||
if (!FileLoader.getInstance().isInCache(currentPath)) {
|
|
||||||
if (FileLoader.getInstance().runtimeHack != null) {
|
|
||||||
FileLoader.getInstance().runtimeHack.trackAlloc(bitmap.getRowBytes() * bitmap.getHeight());
|
|
||||||
}
|
|
||||||
if (canDelete) {
|
|
||||||
setImageBitmap(null);
|
|
||||||
if (Build.VERSION.SDK_INT < 11) {
|
|
||||||
bitmap.recycle();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
setImageBitmap(null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if (drawable instanceof NinePatchDrawable) {
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onDetachedFromWindow() {
|
protected void onDetachedFromWindow() {
|
||||||
super.onDetachedFromWindow();
|
super.onDetachedFromWindow();
|
||||||
if (processDetach) {
|
if (processDetach) {
|
||||||
recycleBitmap(null);
|
imageReceiver.clearImage();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onDraw(Canvas canvas) {
|
protected void onDraw(Canvas canvas) {
|
||||||
try {
|
imageReceiver.imageX = 0;
|
||||||
super.onDraw(canvas);
|
imageReceiver.imageY = 0;
|
||||||
} catch (Exception e) {
|
imageReceiver.imageW = getWidth();
|
||||||
FileLoader.getInstance().removeImage(currentPath);
|
imageReceiver.imageH = getHeight();
|
||||||
currentPath = null;
|
imageReceiver.draw(canvas, 0, 0, imageReceiver.imageW, imageReceiver.imageH);
|
||||||
setImage(last_path, last_httpUrl, last_filter, last_placeholder, last_placeholderBitmap, last_size);
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
|
||||||
public void setImageResourceMy(int resId) {
|
public void setImageResourceMy(int resId) {
|
||||||
if (ignoreLayout) {
|
if (ignoreLayout) {
|
||||||
makeRequest = false;
|
makeRequest = false;
|
||||||
@ -207,25 +111,7 @@ public class BackupImageView extends ImageView {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setImageResource(int resId) {
|
|
||||||
if (resId != 0) {
|
|
||||||
recycleBitmap(null);
|
|
||||||
}
|
|
||||||
currentPath = null;
|
|
||||||
last_path = null;
|
|
||||||
last_httpUrl = null;
|
|
||||||
last_filter = null;
|
|
||||||
last_placeholder = 0;
|
|
||||||
last_size = 0;
|
|
||||||
last_placeholderBitmap = null;
|
|
||||||
if (ignoreLayout) {
|
|
||||||
makeRequest = false;
|
|
||||||
}
|
|
||||||
super.setImageResource(resId);
|
|
||||||
if (ignoreLayout) {
|
|
||||||
makeRequest = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setImageBitmapMy(Bitmap bitmap) {
|
public void setImageBitmapMy(Bitmap bitmap) {
|
||||||
if (ignoreLayout) {
|
if (ignoreLayout) {
|
||||||
@ -238,29 +124,5 @@ public class BackupImageView extends ImageView {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setImageBitmap(Bitmap bitmap) {
|
*/
|
||||||
if (bitmap != null) {
|
|
||||||
recycleBitmap(null);
|
|
||||||
}
|
|
||||||
currentPath = null;
|
|
||||||
last_path = null;
|
|
||||||
last_httpUrl = null;
|
|
||||||
last_filter = null;
|
|
||||||
last_placeholder = 0;
|
|
||||||
last_size = 0;
|
|
||||||
last_placeholderBitmap = null;
|
|
||||||
if (ignoreLayout) {
|
|
||||||
makeRequest = false;
|
|
||||||
}
|
|
||||||
super.setImageBitmap(bitmap);
|
|
||||||
if (ignoreLayout) {
|
|
||||||
makeRequest = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override public void requestLayout() {
|
|
||||||
if (makeRequest) {
|
|
||||||
super.requestLayout();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,112 @@
|
|||||||
|
/*
|
||||||
|
* This is the source code of Telegram for Android v. 1.4.x.
|
||||||
|
* It is licensed under GNU GPL v. 2 or later.
|
||||||
|
* You should have received a copy of the license in this archive (see LICENSE).
|
||||||
|
*
|
||||||
|
* Copyright Nikolai Kudashov, 2013-2014.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.telegram.ui.Views;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.graphics.Bitmap;
|
||||||
|
import android.graphics.Canvas;
|
||||||
|
import android.graphics.Paint;
|
||||||
|
import android.graphics.Rect;
|
||||||
|
import android.view.View;
|
||||||
|
|
||||||
|
public class ClippingImageView extends View {
|
||||||
|
private int clipBottom;
|
||||||
|
private int clipLeft;
|
||||||
|
private int clipRight;
|
||||||
|
private int clipTop;
|
||||||
|
private Rect drawRect;
|
||||||
|
private Paint paint;
|
||||||
|
private Bitmap bmp;
|
||||||
|
private onDrawListener drawListener;
|
||||||
|
|
||||||
|
public static interface onDrawListener {
|
||||||
|
public abstract void onDraw();
|
||||||
|
}
|
||||||
|
|
||||||
|
public ClippingImageView(Context context) {
|
||||||
|
super(context);
|
||||||
|
paint = new Paint();
|
||||||
|
paint.setFilterBitmap(true);
|
||||||
|
drawRect = new Rect();
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getClipBottom() {
|
||||||
|
return clipBottom;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getClipHorizontal() {
|
||||||
|
return clipRight;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getClipLeft() {
|
||||||
|
return clipLeft;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getClipRight() {
|
||||||
|
return clipRight;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getClipTop() {
|
||||||
|
return clipTop;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onDraw(Canvas canvas) {
|
||||||
|
if (bmp != null) {
|
||||||
|
if (drawListener != null && getScaleY() != 1) {
|
||||||
|
drawListener.onDraw();
|
||||||
|
}
|
||||||
|
canvas.save();
|
||||||
|
canvas.clipRect(clipLeft / getScaleY(), clipTop / getScaleY(), getWidth() - clipRight / getScaleY(), getHeight() - clipBottom / getScaleY());
|
||||||
|
drawRect.set(0, 0, getWidth(), getHeight());
|
||||||
|
canvas.drawBitmap(this.bmp, null, drawRect, this.paint);
|
||||||
|
canvas.restore();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setClipBottom(int value) {
|
||||||
|
clipBottom = value;
|
||||||
|
invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setClipHorizontal(int value) {
|
||||||
|
clipRight = value;
|
||||||
|
clipLeft = value;
|
||||||
|
invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setClipLeft(int value) {
|
||||||
|
clipLeft = value;
|
||||||
|
invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setClipRight(int value) {
|
||||||
|
clipRight = value;
|
||||||
|
invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setClipTop(int value) {
|
||||||
|
clipTop = value;
|
||||||
|
invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setClipVertical(int value) {
|
||||||
|
clipBottom = value;
|
||||||
|
clipTop = value;
|
||||||
|
invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setImageBitmap(Bitmap bitmap) {
|
||||||
|
bmp = bitmap;
|
||||||
|
invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setOnDrawListener(onDrawListener listener) {
|
||||||
|
drawListener = listener;
|
||||||
|
}
|
||||||
|
}
|
@ -1,105 +0,0 @@
|
|||||||
/*
|
|
||||||
* This is the source code of Telegram for Android v. 1.3.2.
|
|
||||||
* It is licensed under GNU GPL v. 2 or later.
|
|
||||||
* You should have received a copy of the license in this archive (see LICENSE).
|
|
||||||
*
|
|
||||||
* Copyright Nikolai Kudashov, 2013.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package org.telegram.ui.Views;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.graphics.PointF;
|
|
||||||
import android.support.v4.view.ViewPager;
|
|
||||||
import android.util.AttributeSet;
|
|
||||||
import android.view.MotionEvent;
|
|
||||||
|
|
||||||
import org.telegram.messenger.FileLog;
|
|
||||||
|
|
||||||
public class GalleryViewPager extends ViewPager {
|
|
||||||
PointF last;
|
|
||||||
public PZSImageView mCurrentView;
|
|
||||||
|
|
||||||
public GalleryViewPager(Context context) {
|
|
||||||
super(context);
|
|
||||||
}
|
|
||||||
|
|
||||||
public GalleryViewPager(Context context, AttributeSet attrs) {
|
|
||||||
super(context, attrs);
|
|
||||||
}
|
|
||||||
|
|
||||||
private float[] handleMotionEvent(MotionEvent event) {
|
|
||||||
switch (event.getAction() & MotionEvent.ACTION_MASK) {
|
|
||||||
case MotionEvent.ACTION_DOWN:
|
|
||||||
last = new PointF(event.getX(0), event.getY(0));
|
|
||||||
break;
|
|
||||||
case MotionEvent.ACTION_MOVE:
|
|
||||||
case MotionEvent.ACTION_UP:
|
|
||||||
PointF curr = new PointF(event.getX(0), event.getY(0));
|
|
||||||
return new float[] { curr.x - last.x, curr.y - last.y };
|
|
||||||
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onTouchEvent(MotionEvent event) {
|
|
||||||
try {
|
|
||||||
if ((event.getAction() & MotionEvent.ACTION_MASK) == MotionEvent.ACTION_UP) {
|
|
||||||
super.onTouchEvent(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mCurrentView == null) {
|
|
||||||
return super.onTouchEvent(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
float[] difference = handleMotionEvent(event);
|
|
||||||
|
|
||||||
if (difference != null && mCurrentView.getOnRightSide() && difference[0] < 0) {
|
|
||||||
return super.onTouchEvent(event);
|
|
||||||
} else if (difference != null && mCurrentView.getOnLeftSide() && difference[0] > 0) {
|
|
||||||
return super.onTouchEvent(event);
|
|
||||||
} else if (difference == null && (mCurrentView.getOnLeftSide() || mCurrentView.getOnRightSide())) {
|
|
||||||
return super.onTouchEvent(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
} catch (Exception e) {
|
|
||||||
try {
|
|
||||||
getAdapter().notifyDataSetChanged();
|
|
||||||
} catch (Exception e2) {
|
|
||||||
e2.printStackTrace();
|
|
||||||
}
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onInterceptTouchEvent(MotionEvent event) {
|
|
||||||
try {
|
|
||||||
if ((event.getAction() & MotionEvent.ACTION_MASK) == MotionEvent.ACTION_UP) {
|
|
||||||
super.onInterceptTouchEvent(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mCurrentView == null) {
|
|
||||||
return super.onInterceptTouchEvent(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
float[] difference = handleMotionEvent(event);
|
|
||||||
|
|
||||||
if (difference != null && difference.length > 0 && mCurrentView.getOnRightSide() && difference[0] < 0) {
|
|
||||||
return super.onInterceptTouchEvent(event);
|
|
||||||
} else if (difference != null && difference.length > 0 && mCurrentView.getOnLeftSide() && difference[0] > 0) {
|
|
||||||
return super.onInterceptTouchEvent(event);
|
|
||||||
} else if ((difference == null || difference.length == 0) && (mCurrentView.getOnLeftSide() || mCurrentView.getOnRightSide())) {
|
|
||||||
return super.onInterceptTouchEvent(event);
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
@ -108,7 +108,7 @@ public class ImageReceiver {
|
|||||||
isPlaceholder = false;
|
isPlaceholder = false;
|
||||||
FileLoader.getInstance().incrementUseCount(currentPath);
|
FileLoader.getInstance().incrementUseCount(currentPath);
|
||||||
currentImage = new BitmapDrawable(null, bitmap);
|
currentImage = new BitmapDrawable(null, bitmap);
|
||||||
if (!selfSetting && parentView.get() != null) {
|
if (!selfSetting && parentView != null && parentView.get() != null) {
|
||||||
if (imageW != 0) {
|
if (imageW != 0) {
|
||||||
parentView.get().invalidate(imageX, imageY, imageX + imageW, imageY + imageH);
|
parentView.get().invalidate(imageX, imageY, imageX + imageW, imageY + imageH);
|
||||||
} else {
|
} else {
|
||||||
@ -120,7 +120,12 @@ public class ImageReceiver {
|
|||||||
public void setImageBitmap(Bitmap bitmap) {
|
public void setImageBitmap(Bitmap bitmap) {
|
||||||
FileLoader.getInstance().cancelLoadingForImageView(this);
|
FileLoader.getInstance().cancelLoadingForImageView(this);
|
||||||
recycleBitmap(null);
|
recycleBitmap(null);
|
||||||
last_placeholder = new BitmapDrawable(null, bitmap);
|
if (bitmap != null) {
|
||||||
|
last_placeholder = new BitmapDrawable(null, bitmap);
|
||||||
|
} else {
|
||||||
|
last_placeholder = null;
|
||||||
|
}
|
||||||
|
isPlaceholder = true;
|
||||||
currentPath = null;
|
currentPath = null;
|
||||||
last_path = null;
|
last_path = null;
|
||||||
last_httpUrl = null;
|
last_httpUrl = null;
|
||||||
@ -175,13 +180,14 @@ public class ImageReceiver {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void draw(Canvas canvas, int x, int y, int w, int h) {
|
public void draw(Canvas canvas, int x, int y, int w, int h) {
|
||||||
if (!isVisible) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
try {
|
try {
|
||||||
if (currentImage != null) {
|
Drawable bitmapDrawable = currentImage;
|
||||||
int bitmapW = currentImage.getIntrinsicWidth();
|
if (bitmapDrawable == null && last_placeholder != null && last_placeholder instanceof BitmapDrawable) {
|
||||||
int bitmapH = currentImage.getIntrinsicHeight();
|
bitmapDrawable = last_placeholder;
|
||||||
|
}
|
||||||
|
if (bitmapDrawable != null) {
|
||||||
|
int bitmapW = bitmapDrawable.getIntrinsicWidth();
|
||||||
|
int bitmapH = bitmapDrawable.getIntrinsicHeight();
|
||||||
float scaleW = bitmapW / (float)w;
|
float scaleW = bitmapW / (float)w;
|
||||||
float scaleH = bitmapH / (float)h;
|
float scaleH = bitmapH / (float)h;
|
||||||
|
|
||||||
@ -196,19 +202,25 @@ public class ImageReceiver {
|
|||||||
bitmapH /= scaleW;
|
bitmapH /= scaleW;
|
||||||
drawRegion.set(x, y - (bitmapH - h) / 2, x + w, y + (bitmapH + h) / 2);
|
drawRegion.set(x, y - (bitmapH - h) / 2, x + w, y + (bitmapH + h) / 2);
|
||||||
}
|
}
|
||||||
currentImage.setBounds(drawRegion);
|
bitmapDrawable.setBounds(drawRegion);
|
||||||
currentImage.draw(canvas);
|
if (isVisible) {
|
||||||
|
bitmapDrawable.draw(canvas);
|
||||||
|
}
|
||||||
|
|
||||||
canvas.restore();
|
canvas.restore();
|
||||||
} else {
|
} else {
|
||||||
drawRegion.set(x, y, x + w, y + h);
|
drawRegion.set(x, y, x + w, y + h);
|
||||||
currentImage.setBounds(drawRegion);
|
bitmapDrawable.setBounds(drawRegion);
|
||||||
currentImage.draw(canvas);
|
if (isVisible) {
|
||||||
|
bitmapDrawable.draw(canvas);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else if (last_placeholder != null) {
|
} else if (last_placeholder != null) {
|
||||||
drawRegion.set(x, y, x + w, y + h);
|
drawRegion.set(x, y, x + w, y + h);
|
||||||
last_placeholder.setBounds(drawRegion);
|
last_placeholder.setBounds(drawRegion);
|
||||||
last_placeholder.draw(canvas);
|
if (isVisible) {
|
||||||
|
last_placeholder.draw(canvas);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
if (currentPath != null) {
|
if (currentPath != null) {
|
||||||
@ -229,18 +241,24 @@ public class ImageReceiver {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setVisible(boolean value) {
|
public void setVisible(boolean value, boolean invalidate) {
|
||||||
if (isVisible == value) {
|
if (isVisible == value) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
isVisible = value;
|
isVisible = value;
|
||||||
View parent = parentView.get();
|
if (invalidate) {
|
||||||
if (parent != null) {
|
View parent = parentView.get();
|
||||||
parent.invalidate();
|
if (parent != null) {
|
||||||
|
parent.invalidate();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean getVisible() {
|
public boolean getVisible() {
|
||||||
return isVisible;
|
return isVisible;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean hasImage() {
|
||||||
|
return currentImage != null || last_placeholder != null || currentPath != null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -106,16 +106,7 @@ public class NotificationView extends LinearLayout {
|
|||||||
}
|
}
|
||||||
hide(true);
|
hide(true);
|
||||||
|
|
||||||
if (currentChatId != 0) {
|
NotificationCenter.getInstance().postNotificationName(658, currentChatId, currentUserId, currentEncId);
|
||||||
NotificationCenter.getInstance().addToMemCache("push_chat_id", currentChatId);
|
|
||||||
}
|
|
||||||
if (currentUserId != 0) {
|
|
||||||
NotificationCenter.getInstance().addToMemCache("push_user_id", currentUserId);
|
|
||||||
}
|
|
||||||
if (currentEncId != 0) {
|
|
||||||
NotificationCenter.getInstance().addToMemCache("push_enc_id", currentEncId);
|
|
||||||
}
|
|
||||||
NotificationCenter.getInstance().postNotificationName(658);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -1,550 +0,0 @@
|
|||||||
/*
|
|
||||||
* This is the source code of Telegram for Android v. 1.3.2.
|
|
||||||
* It is licensed under GNU GPL v. 2 or later.
|
|
||||||
* You should have received a copy of the license in this archive (see LICENSE).
|
|
||||||
*
|
|
||||||
* Copyright Nikolai Kudashov, 2013.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package org.telegram.ui.Views;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.graphics.Bitmap;
|
|
||||||
import android.graphics.Canvas;
|
|
||||||
import android.graphics.Matrix;
|
|
||||||
import android.graphics.PointF;
|
|
||||||
import android.graphics.RectF;
|
|
||||||
import android.util.AttributeSet;
|
|
||||||
import android.util.FloatMath;
|
|
||||||
import android.util.TypedValue;
|
|
||||||
import android.view.GestureDetector;
|
|
||||||
import android.view.GestureDetector.SimpleOnGestureListener;
|
|
||||||
import android.view.Gravity;
|
|
||||||
import android.view.MotionEvent;
|
|
||||||
import android.view.ViewGroup;
|
|
||||||
import android.widget.TextView;
|
|
||||||
|
|
||||||
import org.telegram.messenger.FileLog;
|
|
||||||
import org.telegram.messenger.LocaleController;
|
|
||||||
import org.telegram.messenger.R;
|
|
||||||
|
|
||||||
public class PZSImageView extends BackupImageView {
|
|
||||||
|
|
||||||
enum ImageScaleType {
|
|
||||||
FitCenter, TopCrop, CenterCrop
|
|
||||||
}
|
|
||||||
|
|
||||||
public ImageScaleType defaultScaleType = ImageScaleType.FitCenter;
|
|
||||||
public ImageScaleType doubleTapScaleType = ImageScaleType.TopCrop;
|
|
||||||
|
|
||||||
// private static final String TAG = "GalleryImageView";
|
|
||||||
|
|
||||||
// wrapped motion event code.
|
|
||||||
protected static final int PZS_ACTION_INIT = 100;
|
|
||||||
protected static final int PZS_ACTION_SCALE = 1001;
|
|
||||||
protected static final int PZS_ACTION_TRANSLATE = 1002;
|
|
||||||
protected static final int PZS_ACTION_SCALE_TO_TRANSLATE = 1003;
|
|
||||||
protected static final int PZS_ACTION_TRANSLATE_TO_SCALE = 1004;
|
|
||||||
protected static final int PZS_ACTION_FIT_CENTER = 1005;
|
|
||||||
protected static final int PZS_ACTION_CENTER_CROP = 1006;
|
|
||||||
protected static final int PZS_ACTION_TO_LEFT_SIDE = 1007;
|
|
||||||
protected static final int PZS_ACTION_TO_RIGHT_SIDE = 1008;
|
|
||||||
protected static final int PZS_ACTION_TOP_CROP = 1009;
|
|
||||||
protected static final int PZS_ACTION_CANCEL = -1;
|
|
||||||
|
|
||||||
private final static float MAX_SCALE_TO_SCREEN = 2.f;
|
|
||||||
private final static float MIN_SCALE_TO_SCREEN = 1.f;
|
|
||||||
|
|
||||||
private static final float MIN_SCALE_SPAN = 10.f;
|
|
||||||
|
|
||||||
// calculated min / max scale ratio based on image & screen size.
|
|
||||||
private float mMinScaleFactor = 1.f;
|
|
||||||
private float mMaxScaleFactor = 2.f;
|
|
||||||
|
|
||||||
public boolean isVideo = false;
|
|
||||||
private boolean mIsFirstDraw = true; // check flag to calculate necessary
|
|
||||||
// init values.
|
|
||||||
private int mImageWidth; // current set image width
|
|
||||||
private int mImageHeight; // current set image height
|
|
||||||
|
|
||||||
private Context mContext;
|
|
||||||
|
|
||||||
public TextView videoText = null;
|
|
||||||
|
|
||||||
public PZSImageView(Context context) {
|
|
||||||
super(context);
|
|
||||||
mContext = context;
|
|
||||||
init();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public PZSImageView(Context context, AttributeSet attrs) {
|
|
||||||
super(context, attrs);
|
|
||||||
mContext = context;
|
|
||||||
init();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public PZSImageView(Context context, AttributeSet attrs, int defStyle) {
|
|
||||||
super(context, attrs, defStyle);
|
|
||||||
mContext = context;
|
|
||||||
init();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void init() {
|
|
||||||
// should use matrix scale type.
|
|
||||||
setScaleType(ScaleType.MATRIX);
|
|
||||||
Matrix mat = getImageMatrix();
|
|
||||||
mat.reset();
|
|
||||||
setImageMatrix(mat);
|
|
||||||
|
|
||||||
gd = new GestureDetector(mContext, new SimpleOnGestureListener() {
|
|
||||||
|
|
||||||
/*@Override
|
|
||||||
public boolean onDoubleTap(MotionEvent event) {
|
|
||||||
int action = parseDoubleTapMotionEvent(event);
|
|
||||||
touchAction(action, event);
|
|
||||||
return true; // indicate event was handled
|
|
||||||
}*/
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onSingleTapConfirmed(MotionEvent ev) {
|
|
||||||
((AbstractGalleryActivity) mContext).topBtn();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
videoText = new TextView(getContext());
|
|
||||||
videoText.setTextColor(0xffffffff);
|
|
||||||
videoText.setBackgroundColor(0x66000000);
|
|
||||||
videoText.setGravity(Gravity.CENTER);
|
|
||||||
videoText.setTextSize(TypedValue.COMPLEX_UNIT_SP, 24);
|
|
||||||
videoText.setText(LocaleController.getString("NoChats", R.string.NoChats));
|
|
||||||
videoText.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.FILL_PARENT, ViewGroup.LayoutParams.FILL_PARENT));
|
|
||||||
}
|
|
||||||
|
|
||||||
GestureDetector gd;
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setImageBitmap(Bitmap bitmap, String imgKey) {
|
|
||||||
super.setImageBitmap(bitmap, imgKey);
|
|
||||||
mIsFirstDraw = true;
|
|
||||||
if (bitmap != null) {
|
|
||||||
mImageWidth = bitmap.getWidth();
|
|
||||||
mImageHeight = bitmap.getHeight();
|
|
||||||
} else {
|
|
||||||
mImageWidth = getWidth();
|
|
||||||
mImageHeight = getHeight();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setImageBitmap(Bitmap bitmap) {
|
|
||||||
super.setImageBitmap(bitmap);
|
|
||||||
mIsFirstDraw = true;
|
|
||||||
if (bitmap != null) {
|
|
||||||
mImageWidth = bitmap.getWidth();
|
|
||||||
mImageHeight = bitmap.getHeight();
|
|
||||||
} else {
|
|
||||||
mImageWidth = getWidth();
|
|
||||||
mImageHeight = getHeight();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setImageBitmapMy(Bitmap bitmap) {
|
|
||||||
super.setImageBitmapMy(bitmap);
|
|
||||||
mIsFirstDraw = true;
|
|
||||||
if (bitmap != null) {
|
|
||||||
mImageWidth = bitmap.getWidth();
|
|
||||||
mImageHeight = bitmap.getHeight();
|
|
||||||
} else {
|
|
||||||
mImageWidth = getWidth();
|
|
||||||
mImageHeight = getHeight();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
|
|
||||||
super.onSizeChanged(w, h, oldw, oldh);
|
|
||||||
mIsFirstDraw = true;
|
|
||||||
if (getDrawable() == null) {
|
|
||||||
mImageHeight = h;
|
|
||||||
mImageWidth = w;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void onDraw(Canvas canvas) {
|
|
||||||
|
|
||||||
if (mIsFirstDraw) {
|
|
||||||
mIsFirstDraw = false;
|
|
||||||
if (defaultScaleType == ImageScaleType.FitCenter)
|
|
||||||
fitCenter();
|
|
||||||
else if (defaultScaleType == ImageScaleType.TopCrop)
|
|
||||||
topCrop();
|
|
||||||
else if (defaultScaleType == ImageScaleType.CenterCrop)
|
|
||||||
centerCrop();
|
|
||||||
calculateScaleFactorLimit();
|
|
||||||
validateMatrix();
|
|
||||||
}
|
|
||||||
|
|
||||||
setImageMatrix(mCurrentMatrix);
|
|
||||||
|
|
||||||
try {
|
|
||||||
super.onDraw(canvas);
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
FileLog.e("tmessages", "trying draw " + currentPath);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void calculateScaleFactorLimit() {
|
|
||||||
|
|
||||||
// set max / min scale factor.
|
|
||||||
mMaxScaleFactor = Math.max(getHeight() * MAX_SCALE_TO_SCREEN
|
|
||||||
/ mImageHeight, getWidth() * MAX_SCALE_TO_SCREEN / mImageWidth);
|
|
||||||
|
|
||||||
mMinScaleFactor = Math.min(getHeight() * MIN_SCALE_TO_SCREEN
|
|
||||||
/ mImageHeight, getWidth() * MIN_SCALE_TO_SCREEN / mImageWidth);
|
|
||||||
|
|
||||||
if (getDrawable() == null) {
|
|
||||||
mMaxScaleFactor = mMinScaleFactor;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onTouchEvent(MotionEvent event) {
|
|
||||||
if (gd.onTouchEvent(event)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
int action = parseMotionEvent(event);
|
|
||||||
touchAction(action, event);
|
|
||||||
return true; // indicate event was handled
|
|
||||||
}
|
|
||||||
|
|
||||||
private void touchAction(int action, MotionEvent event) {
|
|
||||||
switch (action) {
|
|
||||||
case PZS_ACTION_INIT:
|
|
||||||
initGestureAction(event.getX(), event.getY());
|
|
||||||
break;
|
|
||||||
case PZS_ACTION_SCALE:
|
|
||||||
handleScale(event);
|
|
||||||
break;
|
|
||||||
case PZS_ACTION_TRANSLATE:
|
|
||||||
handleTranslate(event);
|
|
||||||
break;
|
|
||||||
case PZS_ACTION_TRANSLATE_TO_SCALE:
|
|
||||||
initGestureAction(event.getX(), event.getY());
|
|
||||||
break;
|
|
||||||
case PZS_ACTION_SCALE_TO_TRANSLATE:
|
|
||||||
int activeIndex = (event.getActionIndex() == 0 ? 1 : 0);
|
|
||||||
initGestureAction(event.getX(activeIndex), event.getY(activeIndex));
|
|
||||||
break;
|
|
||||||
case PZS_ACTION_FIT_CENTER:
|
|
||||||
fitCenter();
|
|
||||||
initGestureAction(event.getX(), event.getY());
|
|
||||||
break;
|
|
||||||
case PZS_ACTION_CENTER_CROP:
|
|
||||||
centerCrop();
|
|
||||||
initGestureAction(event.getX(), event.getY());
|
|
||||||
break;
|
|
||||||
case PZS_ACTION_TOP_CROP:
|
|
||||||
topCrop();
|
|
||||||
initGestureAction(event.getX(), event.getY());
|
|
||||||
break;
|
|
||||||
case PZS_ACTION_TO_LEFT_SIDE:
|
|
||||||
toLeftSide();
|
|
||||||
break;
|
|
||||||
case PZS_ACTION_TO_RIGHT_SIDE:
|
|
||||||
toRightSide();
|
|
||||||
break;
|
|
||||||
case PZS_ACTION_CANCEL:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
// check current position of bitmap.
|
|
||||||
validateMatrix();
|
|
||||||
updateMatrix();
|
|
||||||
}
|
|
||||||
|
|
||||||
private int parseDoubleTapMotionEvent(MotionEvent ev) {
|
|
||||||
float values[] = new float[9];
|
|
||||||
mCurrentMatrix.getValues(values);
|
|
||||||
float scaleNow = values[Matrix.MSCALE_X];
|
|
||||||
float scaleX = (getWidth() - getPaddingLeft() - getPaddingRight())
|
|
||||||
/ (float) mImageWidth;
|
|
||||||
float scaleY = (getHeight() - getPaddingTop() - getPaddingBottom())
|
|
||||||
/ (float) mImageHeight;
|
|
||||||
if (scaleNow >= Math.max(scaleX, scaleY))
|
|
||||||
return PZS_ACTION_FIT_CENTER;
|
|
||||||
else if (scaleNow < Math.max(scaleX, scaleY)) {
|
|
||||||
if (doubleTapScaleType == ImageScaleType.FitCenter)
|
|
||||||
return PZS_ACTION_FIT_CENTER;
|
|
||||||
else if (doubleTapScaleType == ImageScaleType.TopCrop)
|
|
||||||
return PZS_ACTION_TOP_CROP;
|
|
||||||
else if (doubleTapScaleType == ImageScaleType.CenterCrop)
|
|
||||||
return PZS_ACTION_CENTER_CROP;
|
|
||||||
|
|
||||||
}
|
|
||||||
return PZS_ACTION_FIT_CENTER;
|
|
||||||
}
|
|
||||||
|
|
||||||
private int parseMotionEvent(MotionEvent ev) {
|
|
||||||
|
|
||||||
switch (ev.getAction() & MotionEvent.ACTION_MASK) {
|
|
||||||
case MotionEvent.ACTION_DOWN:
|
|
||||||
return PZS_ACTION_INIT;
|
|
||||||
case MotionEvent.ACTION_POINTER_DOWN:
|
|
||||||
// more than one pointer is pressed...
|
|
||||||
return PZS_ACTION_TRANSLATE_TO_SCALE;
|
|
||||||
case MotionEvent.ACTION_UP:
|
|
||||||
case MotionEvent.ACTION_POINTER_UP:
|
|
||||||
if (ev.getPointerCount() == 2) {
|
|
||||||
return PZS_ACTION_SCALE_TO_TRANSLATE;
|
|
||||||
} else {
|
|
||||||
return PZS_ACTION_INIT;
|
|
||||||
}
|
|
||||||
case MotionEvent.ACTION_MOVE:
|
|
||||||
if (ev.getPointerCount() == 1)
|
|
||||||
return PZS_ACTION_TRANSLATE;
|
|
||||||
else if (ev.getPointerCount() == 2)
|
|
||||||
return PZS_ACTION_SCALE;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// ///////////////////////////////////////////////
|
|
||||||
// Related matrix calculation stuffs.
|
|
||||||
// ///////////////////////////////////////////////
|
|
||||||
|
|
||||||
private Matrix mCurrentMatrix = new Matrix();
|
|
||||||
private Matrix mSavedMatrix = new Matrix();
|
|
||||||
|
|
||||||
// Remember some things for zooming
|
|
||||||
private PointF mStartPoint = new PointF();
|
|
||||||
private PointF mMidPoint = new PointF();
|
|
||||||
private float mInitScaleSpan = 1f;
|
|
||||||
|
|
||||||
protected void initGestureAction(float x, float y) {
|
|
||||||
mSavedMatrix.set(mCurrentMatrix);
|
|
||||||
mStartPoint.set(x, y);
|
|
||||||
mInitScaleSpan = 0.f;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void handleScale(MotionEvent event) {
|
|
||||||
if (isVideo) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
float newSpan = spacing(event);
|
|
||||||
|
|
||||||
// if two finger is too close, pointer index is bumped.. so just ignore
|
|
||||||
// it.
|
|
||||||
if (newSpan < MIN_SCALE_SPAN)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (mInitScaleSpan == 0.f) {
|
|
||||||
// init values. scale gesture action is just started.
|
|
||||||
mInitScaleSpan = newSpan;
|
|
||||||
midPoint(mMidPoint, event);
|
|
||||||
} else {
|
|
||||||
float scale = normalizeScaleFactor(mSavedMatrix, newSpan,
|
|
||||||
mInitScaleSpan);
|
|
||||||
mCurrentMatrix.set(mSavedMatrix);
|
|
||||||
mCurrentMatrix.postScale(scale, scale, mMidPoint.x, mMidPoint.y);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private float normalizeScaleFactor(Matrix curMat, float newSpan,
|
|
||||||
float stdSpan) {
|
|
||||||
|
|
||||||
float values[] = new float[9];
|
|
||||||
curMat.getValues(values);
|
|
||||||
float scale = values[Matrix.MSCALE_X];
|
|
||||||
|
|
||||||
if (stdSpan == newSpan) {
|
|
||||||
return scale;
|
|
||||||
} else {
|
|
||||||
float newScaleFactor = newSpan / stdSpan;
|
|
||||||
float candinateScale = scale * newScaleFactor;
|
|
||||||
|
|
||||||
if (candinateScale > mMaxScaleFactor) {
|
|
||||||
return mMaxScaleFactor / scale;
|
|
||||||
} else if (candinateScale < mMinScaleFactor) {
|
|
||||||
return mMinScaleFactor / scale;
|
|
||||||
} else {
|
|
||||||
return newScaleFactor;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void handleTranslate(MotionEvent event) {
|
|
||||||
mCurrentMatrix.set(mSavedMatrix);
|
|
||||||
mCurrentMatrix.postTranslate(event.getX() - mStartPoint.x, event.getY()
|
|
||||||
- mStartPoint.y);
|
|
||||||
}
|
|
||||||
|
|
||||||
private RectF mTraslateLimitRect = new RectF(); // reuse instance.
|
|
||||||
|
|
||||||
public boolean getOnLeftSide() {
|
|
||||||
float values[] = new float[9];
|
|
||||||
mCurrentMatrix.getValues(values);
|
|
||||||
float tranX = values[Matrix.MTRANS_X];
|
|
||||||
return tranX >= mTraslateLimitRect.right;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean getOnRightSide() {
|
|
||||||
float values[] = new float[9];
|
|
||||||
mCurrentMatrix.getValues(values);
|
|
||||||
float tranX = values[Matrix.MTRANS_X];
|
|
||||||
return tranX <= mTraslateLimitRect.left;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void validateMatrix() {
|
|
||||||
float values[] = new float[9];
|
|
||||||
mCurrentMatrix.getValues(values);
|
|
||||||
|
|
||||||
// get current matrix values.
|
|
||||||
float scale = values[Matrix.MSCALE_X];
|
|
||||||
float tranX = values[Matrix.MTRANS_X];
|
|
||||||
float tranY = values[Matrix.MTRANS_Y];
|
|
||||||
|
|
||||||
int imageHeight = (int) (scale * mImageHeight);
|
|
||||||
int imageWidth = (int) (scale * mImageWidth);
|
|
||||||
if (imageHeight == 0 || imageWidth == 0) {
|
|
||||||
imageHeight = getHeight();
|
|
||||||
imageWidth = getWidth();
|
|
||||||
}
|
|
||||||
|
|
||||||
mTraslateLimitRect.setEmpty();
|
|
||||||
// don't think about optimize code. first, just write code case by case.
|
|
||||||
|
|
||||||
// check TOP & BOTTOM
|
|
||||||
if (imageHeight > getHeight()) {
|
|
||||||
// image height is taller than view
|
|
||||||
mTraslateLimitRect.top = getHeight() - imageHeight
|
|
||||||
- getPaddingTop() - getPaddingBottom();
|
|
||||||
mTraslateLimitRect.bottom = 0.f;
|
|
||||||
} else {
|
|
||||||
mTraslateLimitRect.top = mTraslateLimitRect.bottom = (getHeight()
|
|
||||||
- imageHeight - getPaddingTop() - getPaddingBottom()) / 2.f;
|
|
||||||
}
|
|
||||||
|
|
||||||
// check LEFT & RIGHT
|
|
||||||
if (imageWidth > getWidth()) {
|
|
||||||
// image width is longer than view
|
|
||||||
mTraslateLimitRect.left = getWidth() - imageWidth
|
|
||||||
- getPaddingRight() - getPaddingLeft();
|
|
||||||
mTraslateLimitRect.right = 0.f;
|
|
||||||
} else {
|
|
||||||
mTraslateLimitRect.left = mTraslateLimitRect.right = (getWidth()
|
|
||||||
- imageWidth - getPaddingLeft() - getPaddingRight()) / 2.f;
|
|
||||||
}
|
|
||||||
|
|
||||||
float newTranX = tranX;
|
|
||||||
newTranX = Math.max(newTranX, mTraslateLimitRect.left);
|
|
||||||
newTranX = Math.min(newTranX, mTraslateLimitRect.right);
|
|
||||||
|
|
||||||
float newTranY = tranY;
|
|
||||||
newTranY = Math.max(newTranY, mTraslateLimitRect.top);
|
|
||||||
newTranY = Math.min(newTranY, mTraslateLimitRect.bottom);
|
|
||||||
|
|
||||||
values[Matrix.MTRANS_X] = newTranX;
|
|
||||||
values[Matrix.MTRANS_Y] = newTranY;
|
|
||||||
mCurrentMatrix.setValues(values);
|
|
||||||
|
|
||||||
if (!mTraslateLimitRect.contains(tranX, tranY)) {
|
|
||||||
// set new start point.
|
|
||||||
mStartPoint.offset(tranX - newTranX, tranY - newTranY);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void updateMatrix() {
|
|
||||||
setImageMatrix(mCurrentMatrix);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void fitCenter() {
|
|
||||||
// move image to center....
|
|
||||||
mCurrentMatrix.reset();
|
|
||||||
|
|
||||||
float scaleX = (getWidth() - getPaddingLeft() - getPaddingRight())
|
|
||||||
/ (float) mImageWidth;
|
|
||||||
float scaleY = (getHeight() - getPaddingTop() - getPaddingBottom())
|
|
||||||
/ (float) mImageHeight;
|
|
||||||
float scale = Math.min(scaleX, scaleY);
|
|
||||||
|
|
||||||
float dx = (getWidth() - getPaddingLeft() - getPaddingRight() - mImageWidth
|
|
||||||
* scale) / 2.f;
|
|
||||||
float dy = (getHeight() - getPaddingTop() - getPaddingBottom() - mImageHeight
|
|
||||||
* scale) / 2.f;
|
|
||||||
mCurrentMatrix.postScale(scale, scale);
|
|
||||||
mCurrentMatrix.postTranslate(dx, dy);
|
|
||||||
setImageMatrix(mCurrentMatrix);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void toLeftSide() {
|
|
||||||
float values[] = new float[9];
|
|
||||||
mCurrentMatrix.getValues(values);
|
|
||||||
float tranX = values[Matrix.MTRANS_X];
|
|
||||||
mCurrentMatrix.postTranslate(mTraslateLimitRect.right - tranX, 0);
|
|
||||||
setImageMatrix(mCurrentMatrix);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void toRightSide() {
|
|
||||||
float values[] = new float[9];
|
|
||||||
mCurrentMatrix.getValues(values);
|
|
||||||
float tranX = values[Matrix.MTRANS_X];
|
|
||||||
mCurrentMatrix.postTranslate(mTraslateLimitRect.left - tranX, 0);
|
|
||||||
setImageMatrix(mCurrentMatrix);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void centerCrop() {
|
|
||||||
mCurrentMatrix.reset();
|
|
||||||
|
|
||||||
float scaleX = (getWidth() - getPaddingLeft() - getPaddingRight())
|
|
||||||
/ (float) mImageWidth;
|
|
||||||
float scaleY = (getHeight() - getPaddingTop() - getPaddingBottom())
|
|
||||||
/ (float) mImageHeight;
|
|
||||||
float scale = Math.max(scaleX, scaleY);
|
|
||||||
|
|
||||||
float dx = (getWidth() - getPaddingLeft() - getPaddingRight() - mImageWidth
|
|
||||||
* scale) / 2.f;
|
|
||||||
float dy = (getHeight() - getPaddingTop() - getPaddingBottom() - mImageHeight
|
|
||||||
* scale) / 2.f;
|
|
||||||
|
|
||||||
mCurrentMatrix.postScale(scale, scale);
|
|
||||||
mCurrentMatrix.postTranslate(dx, dy);
|
|
||||||
setImageMatrix(mCurrentMatrix);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void topCrop() {
|
|
||||||
mCurrentMatrix.reset();
|
|
||||||
|
|
||||||
float scaleX = (getWidth() - getPaddingLeft() - getPaddingRight())
|
|
||||||
/ (float) mImageWidth;
|
|
||||||
float scaleY = (getHeight() - getPaddingTop() - getPaddingBottom())
|
|
||||||
/ (float) mImageHeight;
|
|
||||||
float scale = Math.max(scaleX, scaleY);
|
|
||||||
|
|
||||||
mCurrentMatrix.postScale(scale, scale);
|
|
||||||
mCurrentMatrix.postTranslate(0, 0);
|
|
||||||
setImageMatrix(mCurrentMatrix);
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Determine the space between the first two fingers */
|
|
||||||
private float spacing(MotionEvent event) {
|
|
||||||
// ...
|
|
||||||
float x = event.getX(0) - event.getX(1);
|
|
||||||
float y = event.getY(0) - event.getY(1);
|
|
||||||
return FloatMath.sqrt(x * x + y * y);
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Calculate the mid point of the first two fingers */
|
|
||||||
private void midPoint(PointF point, MotionEvent event) {
|
|
||||||
// ...
|
|
||||||
float x = event.getX(0) + event.getX(1);
|
|
||||||
float y = event.getY(0) + event.getY(1);
|
|
||||||
point.set(x / 2, y / 2);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,28 +0,0 @@
|
|||||||
/*
|
|
||||||
* This is the source code of Telegram for Android v. 1.3.2.
|
|
||||||
* It is licensed under GNU GPL v. 2 or later.
|
|
||||||
* You should have received a copy of the license in this archive (see LICENSE).
|
|
||||||
*
|
|
||||||
* Copyright Nikolai Kudashov, 2013.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package org.telegram.ui.Views;
|
|
||||||
|
|
||||||
import android.support.v7.app.ActionBarActivity;
|
|
||||||
|
|
||||||
import org.telegram.ui.ApplicationLoader;
|
|
||||||
|
|
||||||
public class PausableActivity extends ActionBarActivity {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void onPause() {
|
|
||||||
super.onPause();
|
|
||||||
ApplicationLoader.lastPauseTime = System.currentTimeMillis();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void onResume() {
|
|
||||||
super.onResume();
|
|
||||||
ApplicationLoader.resetLastPauseTime();
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,5 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
|
|
||||||
<shape android:shape="rectangle" xmlns:android="http://schemas.android.com/apk/res/android">
|
|
||||||
<solid android:color="#dd000000" />
|
|
||||||
</shape>
|
|
@ -1,7 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
|
|
||||||
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
|
||||||
<item android:drawable="@drawable/photocancel_pressed"
|
|
||||||
android:state_pressed="true" />
|
|
||||||
<item android:drawable="@drawable/photocancel" />
|
|
||||||
</selector>
|
|
@ -1,7 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
|
|
||||||
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
|
||||||
<item android:drawable="@drawable/photoload_pressed"
|
|
||||||
android:state_pressed="true" />
|
|
||||||
<item android:drawable="@drawable/photoload" />
|
|
||||||
</selector>
|
|
@ -1,87 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<FrameLayout
|
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_height="fill_parent"
|
|
||||||
android:background="#00000000"
|
|
||||||
android:layout_gravity="top">
|
|
||||||
|
|
||||||
<org.telegram.ui.Views.GalleryViewPager
|
|
||||||
android:id="@+id/gallery_view_pager"
|
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_height="fill_parent"
|
|
||||||
android:layout_gravity="top"/>
|
|
||||||
|
|
||||||
<ProgressBar
|
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_height="3dp"
|
|
||||||
style="?android:attr/progressBarStyleHorizontal"
|
|
||||||
android:progress="50"
|
|
||||||
android:layout_gravity="bottom|center_horizontal"
|
|
||||||
android:id="@+id/action_progress"
|
|
||||||
android:max="100"
|
|
||||||
android:progressDrawable="@drawable/photo_progress"
|
|
||||||
android:layout_marginBottom="48dp"
|
|
||||||
android:layout_marginLeft="6dp"
|
|
||||||
android:layout_marginRight="6dp"/>
|
|
||||||
|
|
||||||
<FrameLayout
|
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_height="48dp"
|
|
||||||
android:layout_gravity="bottom"
|
|
||||||
android:background="#dd000000"
|
|
||||||
android:id="@+id/gallery_view_bottom_view">
|
|
||||||
|
|
||||||
<ImageView
|
|
||||||
android:layout_height="fill_parent"
|
|
||||||
android:layout_width="50dp"
|
|
||||||
android:src="@drawable/ic_ab_share_white"
|
|
||||||
android:scaleType="center"
|
|
||||||
android:id="@+id/gallery_view_share_button"
|
|
||||||
android:background="@drawable/list_selector"/>
|
|
||||||
|
|
||||||
<ImageView
|
|
||||||
android:layout_height="fill_parent"
|
|
||||||
android:layout_width="50dp"
|
|
||||||
android:src="@drawable/ic_ab_delete_white"
|
|
||||||
android:scaleType="center"
|
|
||||||
android:layout_gravity="right"
|
|
||||||
android:id="@+id/gallery_view_delete_button"
|
|
||||||
android:background="@drawable/list_selector"/>
|
|
||||||
|
|
||||||
<TextView
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_marginLeft="60dp"
|
|
||||||
android:layout_marginRight="60dp"
|
|
||||||
android:textSize="17dp"
|
|
||||||
android:maxLines="1"
|
|
||||||
android:textColor="#ffffff"
|
|
||||||
android:gravity="center"
|
|
||||||
android:layout_marginTop="2dp"
|
|
||||||
android:id="@+id/gallery_view_name_text"
|
|
||||||
android:layout_gravity="top"/>
|
|
||||||
|
|
||||||
<TextView
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_marginLeft="60dp"
|
|
||||||
android:layout_marginRight="60dp"
|
|
||||||
android:layout_marginTop="26dp"
|
|
||||||
android:gravity="center"
|
|
||||||
android:textColor="#b8bdbe"
|
|
||||||
android:textSize="14dp"
|
|
||||||
android:id="@+id/gallery_view_time_text"
|
|
||||||
android:layout_gravity="top"/>
|
|
||||||
|
|
||||||
</FrameLayout>
|
|
||||||
|
|
||||||
<TextView
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_marginTop="-70dp"
|
|
||||||
android:id="@+id/fake_title_view"
|
|
||||||
android:textSize="18dp"
|
|
||||||
android:layout_gravity="top|left"/>
|
|
||||||
|
|
||||||
</FrameLayout>
|
|
@ -1,28 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
|
|
||||||
<FrameLayout
|
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_height="fill_parent"
|
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android">
|
|
||||||
|
|
||||||
<org.telegram.ui.Views.PZSImageView
|
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_height="fill_parent"
|
|
||||||
android:id="@+id/page_image"/>
|
|
||||||
|
|
||||||
<TextView android:layout_height="wrap_content"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_gravity="center"
|
|
||||||
android:textSize="26dp"
|
|
||||||
android:textColor="#ffffff"
|
|
||||||
android:background="@drawable/system_black"
|
|
||||||
android:paddingLeft="8dp"
|
|
||||||
android:paddingRight="8dp"
|
|
||||||
android:paddingTop="2dp"
|
|
||||||
android:paddingBottom="2dp"
|
|
||||||
android:clickable="true"
|
|
||||||
android:visibility="gone"
|
|
||||||
android:id="@+id/action_button"/>
|
|
||||||
|
|
||||||
</FrameLayout>
|
|
||||||
|
|
@ -24,48 +24,12 @@
|
|||||||
<item name="android:actionBarItemBackground">@drawable/bar_selector</item>
|
<item name="android:actionBarItemBackground">@drawable/bar_selector</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Theme.TMessages.Gallery" parent="Theme.AppCompat">
|
|
||||||
<item name="android:actionBarStyle">@style/ActionBar.Transparent.TMessages.Gallery</item>
|
|
||||||
<item name="android:windowActionBarOverlay">true</item>
|
|
||||||
<item name="android:colorBackground">@color/gallery_background_color</item>
|
|
||||||
<item name="android:windowBackground">@color/gallery_background_color</item>
|
|
||||||
<item name="android:homeAsUpIndicator">@drawable/ab_icon_up_gallery</item>
|
|
||||||
<item name="android:actionOverflowButtonStyle">@style/ActionBar.Transparent.TMessages.Gallery.ActionButtonOverflow</item>
|
|
||||||
<item name="android:listChoiceBackgroundIndicator">@drawable/list_selector</item>
|
|
||||||
<item name="android:editTextStyle">@style/Theme.TMessages.EditText</item>
|
|
||||||
|
|
||||||
<item name="actionBarStyle">@style/ActionBar.Transparent.TMessages.Gallery</item>
|
|
||||||
<item name="windowActionBarOverlay">true</item>
|
|
||||||
<item name="homeAsUpIndicator">@drawable/ab_icon_up_gallery</item>
|
|
||||||
<item name="actionOverflowButtonStyle">@style/ActionBar.Transparent.TMessages.Gallery.ActionButtonOverflow</item>
|
|
||||||
<item name="listChoiceBackgroundIndicator">@drawable/list_selector</item>
|
|
||||||
|
|
||||||
<!--<item name="android:windowIsTranslucent">true</item>-->
|
|
||||||
<!--<item name="android:backgroundDimEnabled">false</item>-->
|
|
||||||
</style>
|
|
||||||
|
|
||||||
<!--ACTION BAR-->
|
<!--ACTION BAR-->
|
||||||
|
|
||||||
<style name="ActionBar.Transparent.TMessages.Start" parent="android:style/Widget.Holo.Light.ActionBar">
|
<style name="ActionBar.Transparent.TMessages.Start" parent="android:style/Widget.Holo.Light.ActionBar">
|
||||||
<item name="android:background">@color/header</item>
|
<item name="android:background">@color/header</item>
|
||||||
<item name="android:logo">@drawable/transparent</item>
|
<item name="android:logo">@drawable/transparent</item>
|
||||||
<item name="android:titleTextStyle">@style/ActionBar.Transparent.TMessages.Gallery.Title</item>
|
|
||||||
<item name="android:subtitleTextStyle">@style/ActionBar.Transparent.TMessages.Gallery.Subtitle</item>
|
|
||||||
<item name="android:title">""</item>
|
<item name="android:title">""</item>
|
||||||
|
|
||||||
<item name="background">@color/header</item>
|
|
||||||
<item name="logo">@drawable/transparent</item>
|
|
||||||
<item name="title">""</item>
|
|
||||||
<item name="titleTextStyle">@style/ActionBar.Transparent.TMessages.Gallery.Title</item>
|
|
||||||
<item name="subtitleTextStyle">@style/ActionBar.Transparent.TMessages.Gallery.Subtitle</item>
|
|
||||||
</style>
|
|
||||||
|
|
||||||
<style name="ActionBar.Transparent.TMessages.Gallery" parent="Widget.AppCompat.Light.ActionBar">
|
|
||||||
<item name="android:background">#dd000000</item>
|
|
||||||
<item name="android:titleTextStyle">@style/ActionBar.Transparent.TMessages.Gallery.Title</item>
|
|
||||||
|
|
||||||
<item name="background">@drawable/gallery_action_bar</item>
|
|
||||||
<item name="titleTextStyle">@style/ActionBar.Transparent.TMessages.Gallery.Title</item>
|
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<!--ACTION BAR ITEMS-->
|
<!--ACTION BAR ITEMS-->
|
||||||
@ -75,18 +39,6 @@
|
|||||||
<item name="android:textSize">18sp</item>
|
<item name="android:textSize">18sp</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="ActionBar.Transparent.TMessages.Gallery.ActionButtonOverflow" parent="Widget.AppCompat.ActionButton.Overflow">
|
|
||||||
<item name="android:src">@drawable/ic_ab_other_white</item>
|
|
||||||
</style>
|
|
||||||
|
|
||||||
<style name="ActionBar.Transparent.TMessages.Gallery.Title" parent="TextAppearance.AppCompat.Widget.ActionBar.Title">
|
|
||||||
<item name="android:textColor">#ffffffff</item>
|
|
||||||
</style>
|
|
||||||
|
|
||||||
<style name="ActionBar.Transparent.TMessages.Gallery.Subtitle" parent="TextAppearance.AppCompat.Widget.ActionBar.Subtitle">
|
|
||||||
<item name="android:textColor">#ffd7e8f7</item>
|
|
||||||
</style>
|
|
||||||
|
|
||||||
<!--LIST VIEW-->
|
<!--LIST VIEW-->
|
||||||
|
|
||||||
<style name="Theme.TMessages.ListView" parent="@android:style/Widget.ListView">
|
<style name="Theme.TMessages.ListView" parent="@android:style/Widget.ListView">
|
||||||
|
4
gradle/wrapper/gradle-wrapper.properties
vendored
@ -1,6 +1,6 @@
|
|||||||
#Fri Mar 21 14:56:25 MSK 2014
|
#Mon Jun 09 01:00:32 MSK 2014
|
||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
distributionUrl=http\://services.gradle.org/distributions/gradle-1.11-all.zip
|
distributionUrl=http\://services.gradle.org/distributions/gradle-1.12-all.zip
|
||||||
|