mirror of
https://github.com/DrKLO/Telegram.git
synced 2025-01-03 09:49:15 +01:00
parent
dff98476dd
commit
f83a1b56ff
6 changed files with 93 additions and 66 deletions
|
@ -80,7 +80,7 @@ android {
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
minSdkVersion 8
|
minSdkVersion 8
|
||||||
targetSdkVersion 19
|
targetSdkVersion 19
|
||||||
versionCode 331
|
versionCode 332
|
||||||
versionName "1.9.0"
|
versionName "1.9.0"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1364,7 +1364,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
||||||
args.putString("videoPath", videoPath);
|
args.putString("videoPath", videoPath);
|
||||||
VideoEditorActivity fragment = new VideoEditorActivity(args);
|
VideoEditorActivity fragment = new VideoEditorActivity(args);
|
||||||
fragment.setDelegate(this);
|
fragment.setDelegate(this);
|
||||||
presentFragment(fragment);
|
presentFragment(fragment, false, true);
|
||||||
} else {
|
} else {
|
||||||
processSendingVideo(videoPath, 0, 0, 0, 0, null);
|
processSendingVideo(videoPath, 0, 0, 0, 0, null);
|
||||||
}
|
}
|
||||||
|
|
|
@ -629,7 +629,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
||||||
count = info.participants.size();
|
count = info.participants.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (count != 0 && onlineCount > 0) {
|
if (count != 0 && onlineCount > 1) {
|
||||||
onlineText.setText(Html.fromHtml(String.format("%s, <font color='#357aa8'>%d %s</font>", LocaleController.formatPluralString("Members", count), onlineCount, LocaleController.getString("Online", R.string.Online))));
|
onlineText.setText(Html.fromHtml(String.format("%s, <font color='#357aa8'>%d %s</font>", LocaleController.formatPluralString("Members", count), onlineCount, LocaleController.getString("Online", R.string.Online))));
|
||||||
} else {
|
} else {
|
||||||
onlineText.setText(LocaleController.formatPluralString("Members", count));
|
onlineText.setText(LocaleController.formatPluralString("Members", count));
|
||||||
|
|
|
@ -760,15 +760,16 @@ public class LaunchActivity extends Activity implements ActionBarLayout.ActionBa
|
||||||
|
|
||||||
public void fixLayout() {
|
public void fixLayout() {
|
||||||
if (AndroidUtilities.isTablet()) {
|
if (AndroidUtilities.isTablet()) {
|
||||||
final ViewTreeObserver obs = actionBarLayout.getViewTreeObserver();
|
actionBarLayout.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
|
||||||
obs.addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
|
|
||||||
@Override
|
@Override
|
||||||
public void onGlobalLayout() {
|
public void onGlobalLayout() {
|
||||||
needLayout();
|
needLayout();
|
||||||
|
if (actionBarLayout != null) {
|
||||||
if (Build.VERSION.SDK_INT < 16) {
|
if (Build.VERSION.SDK_INT < 16) {
|
||||||
obs.removeGlobalOnLayoutListener(this);
|
actionBarLayout.getViewTreeObserver().removeGlobalOnLayoutListener(this);
|
||||||
} else {
|
} else {
|
||||||
obs.removeOnGlobalLayoutListener(this);
|
actionBarLayout.getViewTreeObserver().removeOnGlobalLayoutListener(this);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -12,6 +12,7 @@ import android.annotation.TargetApi;
|
||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
import android.graphics.SurfaceTexture;
|
import android.graphics.SurfaceTexture;
|
||||||
import android.media.MediaPlayer;
|
import android.media.MediaPlayer;
|
||||||
|
import android.os.Build;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.view.Gravity;
|
import android.view.Gravity;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
|
@ -76,6 +77,7 @@ public class VideoEditorActivity extends BaseFragment implements TextureView.Sur
|
||||||
|
|
||||||
private final Object sync = new Object();
|
private final Object sync = new Object();
|
||||||
private Thread thread = null;
|
private Thread thread = null;
|
||||||
|
private long createTime = 0;
|
||||||
|
|
||||||
private int rotationValue = 0;
|
private int rotationValue = 0;
|
||||||
private int originalWidth = 0;
|
private int originalWidth = 0;
|
||||||
|
@ -106,7 +108,7 @@ public class VideoEditorActivity extends BaseFragment implements TextureView.Sur
|
||||||
AndroidUtilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (videoPlayer.isPlaying()) {
|
if (videoPlayer != null && videoPlayer.isPlaying()) {
|
||||||
float startTime = videoTimelineView.getLeftProgress() * videoDuration;
|
float startTime = videoTimelineView.getLeftProgress() * videoDuration;
|
||||||
float endTime = videoTimelineView.getRightProgress() * videoDuration;
|
float endTime = videoTimelineView.getRightProgress() * videoDuration;
|
||||||
if (startTime == endTime) {
|
if (startTime == endTime) {
|
||||||
|
@ -186,6 +188,15 @@ public class VideoEditorActivity extends BaseFragment implements TextureView.Sur
|
||||||
if (videoTimelineView != null) {
|
if (videoTimelineView != null) {
|
||||||
videoTimelineView.destroy();
|
videoTimelineView.destroy();
|
||||||
}
|
}
|
||||||
|
if (videoPlayer != null) {
|
||||||
|
try {
|
||||||
|
videoPlayer.stop();
|
||||||
|
videoPlayer.release();
|
||||||
|
videoPlayer = null;
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -323,13 +334,15 @@ public class VideoEditorActivity extends BaseFragment implements TextureView.Sur
|
||||||
parent.removeView(fragmentView);
|
parent.removeView(fragmentView);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
fixLayoutInternal();
|
||||||
|
createTime = System.currentTimeMillis();
|
||||||
return fragmentView;
|
return fragmentView;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onResume() {
|
public void onResume() {
|
||||||
super.onResume();
|
super.onResume();
|
||||||
fixLayout();
|
fixLayoutInternal();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -479,14 +492,7 @@ public class VideoEditorActivity extends BaseFragment implements TextureView.Sur
|
||||||
textureView.setLayoutParams(layoutParams);
|
textureView.setLayoutParams(layoutParams);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void fixLayout() {
|
private void fixLayoutInternal() {
|
||||||
if (originalSizeTextView == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
originalSizeTextView.getViewTreeObserver().addOnPreDrawListener(new ViewTreeObserver.OnPreDrawListener() {
|
|
||||||
@Override
|
|
||||||
public boolean onPreDraw() {
|
|
||||||
originalSizeTextView.getViewTreeObserver().removeOnPreDrawListener(this);
|
|
||||||
if (!AndroidUtilities.isTablet() && getParentActivity().getResources().getConfiguration().orientation == Configuration.ORIENTATION_LANDSCAPE) {
|
if (!AndroidUtilities.isTablet() && getParentActivity().getResources().getConfiguration().orientation == Configuration.ORIENTATION_LANDSCAPE) {
|
||||||
FrameLayout.LayoutParams layoutParams = (FrameLayout.LayoutParams) videoContainerView.getLayoutParams();
|
FrameLayout.LayoutParams layoutParams = (FrameLayout.LayoutParams) videoContainerView.getLayoutParams();
|
||||||
layoutParams.topMargin = AndroidUtilities.dp(16);
|
layoutParams.topMargin = AndroidUtilities.dp(16);
|
||||||
|
@ -534,9 +540,29 @@ public class VideoEditorActivity extends BaseFragment implements TextureView.Sur
|
||||||
}
|
}
|
||||||
fixVideoSize();
|
fixVideoSize();
|
||||||
videoTimelineView.clearFrames();
|
videoTimelineView.clearFrames();
|
||||||
return false;
|
}
|
||||||
|
|
||||||
|
private void fixLayout() {
|
||||||
|
if (originalSizeTextView == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (createTime < System.currentTimeMillis() - 3000) {
|
||||||
|
originalSizeTextView.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
|
||||||
|
@Override
|
||||||
|
public void onGlobalLayout() {
|
||||||
|
if (originalSizeTextView != null) {
|
||||||
|
if (Build.VERSION.SDK_INT < 16) {
|
||||||
|
originalSizeTextView.getViewTreeObserver().removeGlobalOnLayoutListener(this);
|
||||||
|
} else {
|
||||||
|
originalSizeTextView.getViewTreeObserver().removeOnGlobalLayoutListener(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fixLayoutInternal();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
fixLayoutInternal();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void play() {
|
private void play() {
|
||||||
|
@ -571,7 +597,7 @@ public class VideoEditorActivity extends BaseFragment implements TextureView.Sur
|
||||||
});
|
});
|
||||||
videoPlayer.start();
|
videoPlayer.start();
|
||||||
synchronized (sync) {
|
synchronized (sync) {
|
||||||
if (thread != null) {
|
if (thread == null) {
|
||||||
thread = new Thread(progressRunnable);
|
thread = new Thread(progressRunnable);
|
||||||
thread.start();
|
thread.start();
|
||||||
}
|
}
|
||||||
|
|
|
@ -69,7 +69,7 @@ public class AvatarUpdater implements NotificationCenter.NotificationCenterDeleg
|
||||||
|
|
||||||
public void openGallery() {
|
public void openGallery() {
|
||||||
try {
|
try {
|
||||||
Intent photoPickerIntent = new Intent(Intent.ACTION_PICK);
|
Intent photoPickerIntent = new Intent(Intent.ACTION_GET_CONTENT);
|
||||||
photoPickerIntent.setType("image/*");
|
photoPickerIntent.setType("image/*");
|
||||||
parentFragment.getParentActivity().startActivityForResult(photoPickerIntent, 14);
|
parentFragment.getParentActivity().startActivityForResult(photoPickerIntent, 14);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
|
Loading…
Reference in a new issue