diff options
author | Wu-cheng Li <wuchengli@google.com> | 2011-07-05 17:54:29 +0800 |
---|---|---|
committer | Wu-cheng Li <wuchengli@google.com> | 2011-07-18 05:26:47 +0800 |
commit | 750173a4d20f1e8d6607edb3ada6be5166d0cd82 (patch) | |
tree | 783701cf389c5b1f63efc43ed01bb712959ea8c0 /src/com/android/camera | |
parent | 5281216188a75f5a2edd87ef5f7358a956f17e28 (diff) | |
download | LegacyCamera-750173a4d20f1e8d6607edb3ada6be5166d0cd82.zip LegacyCamera-750173a4d20f1e8d6607edb3ada6be5166d0cd82.tar.gz LegacyCamera-750173a4d20f1e8d6607edb3ada6be5166d0cd82.tar.bz2 |
Add a share application list in share popup.
bug:4725978
Change-Id: Id7a8b24fd7785f2d7dd316b5000f8ae3f3e8c567
Diffstat (limited to 'src/com/android/camera')
-rw-r--r-- | src/com/android/camera/Camera.java | 84 | ||||
-rw-r--r-- | src/com/android/camera/VideoCamera.java | 95 | ||||
-rw-r--r-- | src/com/android/camera/ui/RotateLayout.java | 51 | ||||
-rw-r--r-- | src/com/android/camera/ui/SharePopup.java | 159 |
4 files changed, 202 insertions, 187 deletions
diff --git a/src/com/android/camera/Camera.java b/src/com/android/camera/Camera.java index 02e9eab..1183de0 100644 --- a/src/com/android/camera/Camera.java +++ b/src/com/android/camera/Camera.java @@ -168,16 +168,16 @@ public class Camera extends ActivityBase implements View.OnClickListener, private GLRootView mGLRootView; - // A button showing the last captured picture thumbnail. Clicking on it will - // show the share popup window. - private RotateImageView mThumbnailButton; // A popup window that contains a bigger thumbnail and a list of apps to share. private SharePopup mSharePopup; // The bitmap of the last captured picture thumbnail and the URI of the // original picture. private Thumbnail mThumbnail; - // A button sharing the last picture. - private RotateImageView mShareButton; + // A button that contains the thumbnail and the share icon. + private View mShareButton; + // An imageview showing showing the last captured picture thumbnail. + private RotateImageView mThumbnailView; + private RotateImageView mShareIcon; private RotateImageView mCameraSwitchIcon; private RotateImageView mVideoSwitchIcon; @@ -386,7 +386,6 @@ public class Camera extends ActivityBase implements View.OnClickListener, if (!mIsImageCaptureIntent) { // no thumbnail in image capture intent findViewById(R.id.camera_switch).setOnClickListener(this); initThumbnailButton(); - if (mShareButton != null) mShareButton.setOnClickListener(this); } // Initialize shutter button. @@ -430,7 +429,7 @@ public class Camera extends ActivityBase implements View.OnClickListener, } private void initThumbnailButton() { - mThumbnailButton.setOnClickListener(this); + mShareButton.setOnClickListener(this); // Load the thumbnail from the disk. mThumbnail = Thumbnail.loadFrom(new File(getFilesDir(), LAST_THUMB_FILENAME)); updateThumbnailButton(); @@ -443,9 +442,9 @@ public class Camera extends ActivityBase implements View.OnClickListener, mThumbnail = Thumbnail.getLastImageThumbnail(mContentResolver); } if (mThumbnail != null) { - mThumbnailButton.setBitmap(mThumbnail.getBitmap()); + mThumbnailView.setBitmap(mThumbnail.getBitmap()); } else { - mThumbnailButton.setBitmap(null); + mThumbnailView.setBitmap(null); } } @@ -867,7 +866,7 @@ public class Camera extends ActivityBase implements View.OnClickListener, int inSampleSize = Util.nextPowerOf2(ratio); mThumbnail = Thumbnail.createThumbnail(data, orientation, inSampleSize, uri); if (mThumbnail != null) { - mThumbnailButton.setBitmap(mThumbnail.getBitmap()); + mThumbnailView.setBitmap(mThumbnail.getBitmap()); } sendBroadcast(new Intent("com.android.camera.NEW_PICTURE", uri)); } @@ -981,8 +980,9 @@ public class Camera extends ActivityBase implements View.OnClickListener, setContentView(R.layout.camera); } mFocusRectangle = (FocusRectangle) findViewById(R.id.focus_rectangle); - mThumbnailButton = (RotateImageView) findViewById(R.id.review_thumbnail); - mShareButton = (RotateImageView) findViewById(R.id.btn_share); + mShareButton = findViewById(R.id.share_button); + mThumbnailView = (RotateImageView) findViewById(R.id.thumbnail); + mShareIcon = (RotateImageView) findViewById(R.id.share_icon); mCameraSwitchIcon = (RotateImageView) findViewById(R.id.camera_switch_icon); mVideoSwitchIcon = (RotateImageView) findViewById(R.id.video_switch_icon); @@ -1231,8 +1231,8 @@ public class Camera extends ActivityBase implements View.OnClickListener, private void setOrientationIndicator(int degree) { if (mHeadUpDisplay != null) mHeadUpDisplay.setOrientation(mOrientationCompensation); - if (mThumbnailButton != null) mThumbnailButton.setDegree(degree); - if (mShareButton != null) mShareButton.setDegree(degree); + if (mThumbnailView != null) mThumbnailView.setDegree(degree); + if (mShareIcon != null) mShareIcon.setDegree(degree); if (mCameraSwitchIcon != null) mCameraSwitchIcon.setDegree(degree); if (mVideoSwitchIcon != null) mVideoSwitchIcon.setDegree(degree); if (mSharePopup != null) mSharePopup.setOrientation(degree); @@ -1255,31 +1255,24 @@ public class Camera extends ActivityBase implements View.OnClickListener, updateStorageHint(); } + @Override public void onClick(View v) { switch (v.getId()) { + case R.id.share_button: + if (isCameraIdle() && mThumbnail != null) { + showSharePopup(); + } + break; case R.id.btn_retake: hidePostCaptureAlert(); startPreview(); break; - case R.id.review_thumbnail: - if (isCameraIdle() && mThumbnail != null) { - Util.viewUri(mThumbnail.getUri(), this); - } - break; case R.id.btn_done: doAttach(); break; case R.id.btn_cancel: doCancel(); break; - case R.id.btn_gallery: - gotoGallery(); - break; - case R.id.btn_share: - if (isCameraIdle() && mThumbnail != null) { - createSharePopup(); - } - break; } } @@ -1519,7 +1512,7 @@ public class Camera extends ActivityBase implements View.OnClickListener, hidePostCaptureAlert(); } - dismissSharePopup(); + if (mSharePopup != null) mSharePopup.dismiss(); if (mDidRegister) { unregisterReceiver(mReceiver); @@ -2447,36 +2440,13 @@ public class Camera extends ActivityBase implements View.OnClickListener, mNotSelectableToast.show(); } - private void createSharePopup() { - if (mSharePopup != null) mSharePopup.dismiss(); - mSharePopup = new SharePopup(this, mThumbnail.getUri(), - mThumbnail.getBitmap(), mOrientationCompensation, mThumbnailButton); - mSharePopup.showAtLocation(mThumbnailButton, Gravity.NO_GRAVITY, 0, 0); - } - - private void dismissSharePopup() { - if (mSharePopup != null) { - mSharePopup.dismiss(); - mSharePopup = null; - } - } - - private void onShareButtonClicked() { - if (mPausing) return; - - // Share the last captured picture. - if (mThumbnail != null) { - Intent intent = new Intent(Intent.ACTION_SEND); - intent.setType("image/jpeg"); - intent.putExtra(Intent.EXTRA_STREAM, mThumbnail.getUri()); - startActivity(Intent.createChooser(intent, getString(R.string.share_picture_via))); - } else { // No last picture - if (mNoShareToast == null) { - mNoShareToast = Toast.makeText(this, - getResources().getString(R.string.no_picture_to_share), Toast.LENGTH_SHORT); - } - mNoShareToast.show(); + private void showSharePopup() { + Uri uri = mThumbnail.getUri(); + if (mSharePopup == null || !uri.equals(mSharePopup.getUri())) { + mSharePopup = new SharePopup(this, uri, mThumbnail.getBitmap(), "image/jpeg", + mOrientationCompensation, mShareButton); } + mSharePopup.showAtLocation(mThumbnailView, Gravity.NO_GRAVITY, 0, 0); } private class MyIndicatorWheelListener implements IndicatorWheel.Listener { diff --git a/src/com/android/camera/VideoCamera.java b/src/com/android/camera/VideoCamera.java index 31444c4..300d31f 100644 --- a/src/com/android/camera/VideoCamera.java +++ b/src/com/android/camera/VideoCamera.java @@ -150,19 +150,19 @@ public class VideoCamera extends ActivityBase private View mReviewControl; private Toast mNoShareToast; - // A button showing the last captured video thumbnail. Clicking on it will - // show the share popup window. - private RotateImageView mThumbnailButton; + // An review image having same size as preview. It is displayed when + // recording is stopped in capture intent. + private ImageView mReviewImage; // A popup window that contains a bigger thumbnail and a list of apps to share. private SharePopup mSharePopup; // The bitmap of the last captured video thumbnail and the URI of the // original video. private Thumbnail mThumbnail; - // An review image having same size as preview. It is displayed when - // recording is stopped in capture intent. - private ImageView mReviewImage; - // A button sharing the last picture. - private RotateImageView mShareButton; + // A button that contains the thumbnail and the share icon. + private View mShareButton; + // An imageview showing showing the last captured picture thumbnail. + private RotateImageView mThumbnailView; + private RotateImageView mShareIcon; private RotateImageView mCameraSwitchIcon; private RotateImageView mVideoSwitchIcon; private ShutterButton mShutterButton; @@ -406,8 +406,7 @@ public class VideoCamera extends ActivityBase setContentView(R.layout.video_camera); initThumbnailButton(); - mShareButton = (RotateImageView) findViewById(R.id.btn_share); - if (mShareButton != null) mShareButton.setOnClickListener(this); + mShareIcon = (RotateImageView) findViewById(R.id.share_icon); mSwitcher = (SwitcherSet) findViewById(R.id.camera_switch); mSwitcher.setVisibility(View.VISIBLE); mSwitcher.setOnSwitchListener(this); @@ -418,6 +417,8 @@ public class VideoCamera extends ActivityBase mPreviewFrameLayout.setOnSizeChangedListener(this); mReviewImage = (ImageView) findViewById(R.id.review_image); + mShareButton = findViewById(R.id.share_button); + mShareIcon = (RotateImageView) findViewById(R.id.share_icon); mCameraSwitchIcon = (RotateImageView) findViewById(R.id.camera_switch_icon); mVideoSwitchIcon = (RotateImageView) findViewById(R.id.video_switch_icon); @@ -607,8 +608,8 @@ public class VideoCamera extends ActivityBase private void setOrientationIndicator(int degree) { if (mHeadUpDisplay != null) mHeadUpDisplay.setOrientation(mOrientationCompensation); - if (mThumbnailButton != null) mThumbnailButton.setDegree(degree); - if (mShareButton != null) mShareButton.setDegree(degree); + if (mThumbnailView != null) mThumbnailView.setDegree(degree); + if (mShareIcon != null) mShareIcon.setDegree(degree); if (mCameraSwitchIcon != null) mCameraSwitchIcon.setDegree(degree); if (mVideoSwitchIcon != null) mVideoSwitchIcon.setDegree(degree); if (mSharePopup != null) mSharePopup.setOrientation(degree); @@ -623,8 +624,14 @@ public class VideoCamera extends ActivityBase } } + @Override public void onClick(View v) { switch (v.getId()) { + case R.id.share_button: + if (!mMediaRecorderRecording && mThumbnail != null) { + showSharePopup(); + } + break; case R.id.btn_retake: deleteCurrentVideo(); hideAlert(); @@ -639,19 +646,6 @@ public class VideoCamera extends ActivityBase stopVideoRecording(); doReturnToCaller(false); break; - case R.id.review_thumbnail: - if (!mMediaRecorderRecording && mThumbnail != null) { - Util.viewUri(mThumbnail.getUri(), this); - } - break; - case R.id.btn_gallery: - gotoGallery(); - break; - case R.id.btn_share: - if (!mMediaRecorderRecording && mThumbnail != null) { - createSharePopup(); - } - break; } } @@ -981,7 +975,7 @@ public class VideoCamera extends ActivityBase finishRecorderAndCloseCamera(); - dismissSharePopup(); + if (mSharePopup != null) mSharePopup.dismiss(); if (mReceiver != null) { unregisterReceiver(mReceiver); @@ -1496,7 +1490,7 @@ public class VideoCamera extends ActivityBase mCurrentVideoFilename, Video.Thumbnails.MINI_KIND); if (videoFrame != null) { mThumbnail = new Thumbnail(mCurrentVideoUri, videoFrame, 0); - mThumbnailButton.setBitmap(mThumbnail.getBitmap()); + mThumbnailView.setBitmap(mThumbnail.getBitmap()); } } } @@ -1619,8 +1613,8 @@ public class VideoCamera extends ActivityBase } private void initThumbnailButton() { - mThumbnailButton = (RotateImageView) findViewById(R.id.review_thumbnail); - mThumbnailButton.setOnClickListener(this); + mThumbnailView = (RotateImageView) findViewById(R.id.thumbnail); + findViewById(R.id.share_button).setOnClickListener(this); // Load the thumbnail from the disk. mThumbnail = Thumbnail.loadFrom(new File(getFilesDir(), LAST_THUMB_FILENAME)); } @@ -1630,9 +1624,9 @@ public class VideoCamera extends ActivityBase mThumbnail = Thumbnail.getLastVideoThumbnail(mContentResolver); } if (mThumbnail != null) { - mThumbnailButton.setBitmap(mThumbnail.getBitmap()); + mThumbnailView.setBitmap(mThumbnail.getBitmap()); } else { - mThumbnailButton.setBitmap(null); + mThumbnailView.setBitmap(null); } } @@ -1921,36 +1915,13 @@ public class VideoCamera extends ActivityBase } - private void createSharePopup() { - if (mSharePopup != null) mSharePopup.dismiss(); - mSharePopup = new SharePopup(this, mThumbnail.getUri(), - mThumbnail.getBitmap(), mOrientationCompensation, mThumbnailButton); - mSharePopup.showAtLocation(mThumbnailButton, Gravity.NO_GRAVITY, 0, 0); - } - - private void dismissSharePopup() { - if (mSharePopup != null) { - mSharePopup.dismiss(); - mSharePopup = null; - } - } - - private void onShareButtonClicked() { - if (mPausing) return; - - // Share the last captured video. - if (mThumbnail != null) { - Intent intent = new Intent(Intent.ACTION_SEND); - intent.setType("video/*"); - intent.putExtra(Intent.EXTRA_STREAM, mThumbnail.getUri()); - startActivity(Intent.createChooser(intent, getString(R.string.share_video_via))); - } else { // No last picture - if (mNoShareToast == null) { - mNoShareToast = Toast.makeText(this, - getResources().getString(R.string.no_video_to_share), Toast.LENGTH_SHORT); - } - mNoShareToast.show(); + private void showSharePopup() { + Uri uri = mThumbnail.getUri(); + if (mSharePopup == null || !uri.equals(mSharePopup.getUri())) { + mSharePopup = new SharePopup(this, uri, mThumbnail.getBitmap(), + "video/*", mOrientationCompensation, mShareButton); } + mSharePopup.showAtLocation(mThumbnailView, Gravity.NO_GRAVITY, 0, 0); } private class MyIndicatorWheelListener implements IndicatorWheel.Listener { @@ -1964,10 +1935,6 @@ public class VideoCamera extends ActivityBase public void onOverriddenPreferencesClicked() { } - - public void onShareButtonClicked() { - VideoCamera.this.onShareButtonClicked(); - } } private class MyCameraPickerListener implements CameraPicker.Listener { diff --git a/src/com/android/camera/ui/RotateLayout.java b/src/com/android/camera/ui/RotateLayout.java index 6e1aa92..c900557 100644 --- a/src/com/android/camera/ui/RotateLayout.java +++ b/src/com/android/camera/ui/RotateLayout.java @@ -17,15 +17,14 @@ package com.android.camera.ui; import android.content.Context; -import android.graphics.Canvas; import android.util.AttributeSet; -import android.view.MotionEvent; import android.view.View; import android.view.ViewGroup; // A RotateLayout is designed to display a single item and provides the // capabilities to rotate the item. class RotateLayout extends ViewGroup { + private static final String TAG = "RotateLayout"; private int mOrientation; private View mChild; @@ -36,6 +35,8 @@ class RotateLayout extends ViewGroup { @Override protected void onFinishInflate() { mChild = getChildAt(0); + mChild.setPivotX(0); + mChild.setPivotY(0); } @Override @@ -57,54 +58,42 @@ class RotateLayout extends ViewGroup { @Override protected void onMeasure(int widthSpec, int heightSpec) { + int w = 0, h = 0; switch(mOrientation) { case 0: case 180: measureChild(mChild, widthSpec, heightSpec); - setMeasuredDimension(mChild.getMeasuredWidth(), mChild.getMeasuredHeight()); + w = mChild.getMeasuredWidth(); + h = mChild.getMeasuredHeight(); break; case 90: case 270: measureChild(mChild, heightSpec, widthSpec); - setMeasuredDimension(mChild.getMeasuredHeight(), mChild.getMeasuredWidth()); + w = mChild.getMeasuredHeight(); + h = mChild.getMeasuredWidth(); break; } - } + setMeasuredDimension(w, h); - @Override - public void dispatchDraw(Canvas canvas) { - int w = getWidth(); - int h = getHeight(); switch (mOrientation) { + case 0: + mChild.setTranslationX(0); + mChild.setTranslationY(0); + break; case 90: - canvas.translate(0, h); - canvas.rotate(-mOrientation); + mChild.setTranslationX(0); + mChild.setTranslationY(h); break; case 180: - canvas.rotate(-mOrientation, w / 2, h / 2); + mChild.setTranslationX(w); + mChild.setTranslationY(h); break; case 270: - canvas.translate(w, 0); - canvas.rotate(-mOrientation); + mChild.setTranslationX(w); + mChild.setTranslationY(0); break; } - super.dispatchDraw(canvas); - } - - @Override - public boolean dispatchTouchEvent(MotionEvent event) { - float x = event.getX(); - float y = event.getY(); - float width = getWidth(); - float height = getHeight(); - switch (mOrientation) { - case 90: event.setLocation(height - y, x); break; - case 180: event.setLocation(width - x, height - y); break; - case 270: event.setLocation(y, width - x); break; - } - boolean result = mChild.dispatchTouchEvent(event); - event.setLocation(x, y); - return result; + mChild.setRotation(-mOrientation); } // Rotate the view counter-clockwise diff --git a/src/com/android/camera/ui/SharePopup.java b/src/com/android/camera/ui/SharePopup.java index d182e2d..fc26c90 100644 --- a/src/com/android/camera/ui/SharePopup.java +++ b/src/com/android/camera/ui/SharePopup.java @@ -20,7 +20,11 @@ import com.android.camera.R; import com.android.camera.Util; import android.app.Activity; +import android.content.ComponentName; import android.content.Context; +import android.content.Intent; +import android.content.pm.PackageManager; +import android.content.pm.ResolveInfo; import android.content.res.Resources; import android.graphics.Bitmap; import android.graphics.drawable.ColorDrawable; @@ -29,19 +33,41 @@ import android.util.DisplayMetrics; import android.view.LayoutInflater; import android.view.MotionEvent; import android.view.View; +import android.view.ViewGroup; import android.view.ViewGroup.LayoutParams; import android.view.ViewGroup.MarginLayoutParams; import android.view.WindowManager; -import android.view.animation.Animation; -import android.view.animation.AnimationUtils; +import android.widget.AdapterView; import android.widget.ImageView; +import android.widget.ListView; import android.widget.PopupWindow; +import android.widget.SimpleAdapter; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; // A popup window that contains a big thumbnail and a list of apps to share. public class SharePopup extends PopupWindow implements View.OnClickListener, - View.OnTouchListener { + View.OnTouchListener, AdapterView.OnItemClickListener { + private static final String TAG = "SharePopup"; private Context mContext; private Uri mUri; + private String mMimeType; + private ImageView mThumbnail; + private int mBitmapWidth; + private int mBitmapHeight; + // A view that contains a thumbnail and a share view. + private ViewGroup mRootView; + // A view that contains the title and the list of applications to share. + private View mShareView; + // The list of the applications to share. + private ListView mShareList; + // A rotated view that contains the share view. + private RotateLayout mShareViewRotateLayout; + // A rotated view that contains the thumbnail. + private RotateLayout mThumbnailRotateLayout; + private ArrayList<ComponentName> mComponent = new ArrayList<ComponentName>(); // The maximum width of the thumbnail in landscape orientation. private final float mImageMaxWidthLandscape; @@ -51,26 +77,31 @@ public class SharePopup extends PopupWindow implements View.OnClickListener, private final float mImageMaxWidthPortrait; // The maximum height of the thumbnail in portrait orientation. private final float mImageMaxHeightPortrait; + // The width of the share list in landscape mode. + private final float mShareListWidthLandscape; - private ImageView mThumbnail; - private int mBitmapWidth, mBitmapHeight; - private RotateLayout mRotateLayout; - - public SharePopup(Activity activity, Uri uri, Bitmap bitmap, int orientation, View anchor) { + public SharePopup(Activity activity, Uri uri, Bitmap bitmap, String mimeType, int orientation, + View anchor) { super(activity); - // Initailize variables + // Initialize variables mContext = activity; mUri = uri; + mMimeType = mimeType; LayoutInflater inflater = (LayoutInflater) mContext.getSystemService( Context.LAYOUT_INFLATER_SERVICE); - View contentView = inflater.inflate(R.layout.share_popup, null, false); + ViewGroup sharePopup = (ViewGroup) inflater.inflate(R.layout.share_popup, null, false); // This is required because popup window is full screen. - contentView.setOnTouchListener(this); - mRotateLayout = (RotateLayout) contentView.findViewById(R.id.rotate_layout); - mThumbnail = (ImageView) contentView.findViewById(R.id.expanded_thumbnail); + sharePopup.setOnTouchListener(this); + mShareViewRotateLayout = (RotateLayout) sharePopup.findViewById(R.id.share_view_rotate_layout); + mThumbnailRotateLayout = (RotateLayout) sharePopup.findViewById(R.id.thumbnail_rotate_layout); + mShareList = (ListView) sharePopup.findViewById(R.id.share_list); + mShareView = sharePopup.findViewById(R.id.share_view); + mThumbnail = (ImageView) sharePopup.findViewById(R.id.thumbnail); + mRootView = (ViewGroup) sharePopup.findViewById(R.id.root); mThumbnail.setImageBitmap(bitmap); mThumbnail.setOnClickListener(this); + sharePopup.findViewById(R.id.collapse_button).setOnClickListener(this); mBitmapWidth = bitmap.getWidth(); mBitmapHeight = bitmap.getHeight(); Resources res = mContext.getResources(); @@ -78,57 +109,77 @@ public class SharePopup extends PopupWindow implements View.OnClickListener, mImageMaxHeightLandscape = res.getDimension(R.dimen.share_image_max_height_landscape); mImageMaxWidthPortrait = res.getDimension(R.dimen.share_image_max_width_portrait); mImageMaxHeightPortrait = res.getDimension(R.dimen.share_image_max_height_portrait); + mShareListWidthLandscape = res.getDimension(R.dimen.share_list_width_landscape); // Initialize popup window setWidth(WindowManager.LayoutParams.MATCH_PARENT); setHeight(WindowManager.LayoutParams.MATCH_PARENT); setBackgroundDrawable(new ColorDrawable()); - setContentView(contentView); + setContentView(sharePopup); setOrientation(orientation); + setFocusable(true); + setAnimationStyle(R.style.AnimationPopup); + + initializeLocation(activity, anchor); - // Initialize view location + createShareMenu(); + } + + private void initializeLocation(Activity activity, View anchor) { int location[] = new int[2]; anchor.getLocationOnScreen(location); DisplayMetrics metrics = new DisplayMetrics(); activity.getWindowManager().getDefaultDisplay().getMetrics(metrics); - MarginLayoutParams params = (MarginLayoutParams) mRotateLayout.getLayoutParams(); - params.topMargin = location[1] / 2; - params.rightMargin = (metrics.widthPixels - location[0] - anchor.getWidth()) / 2; - mRotateLayout.setLayoutParams(params); - - // Start animation - Animation fadeIn = AnimationUtils.loadAnimation(mContext, R.anim.grow_fade_in_from_right); - mRotateLayout.startAnimation(fadeIn); + MarginLayoutParams params = (MarginLayoutParams) mRootView.getLayoutParams(); + params.topMargin = location[1]; + params.rightMargin = (metrics.widthPixels - location[0] - anchor.getWidth()); + mRootView.setLayoutParams(params); } public void setOrientation(int orientation) { // Calculate the width and the height of the thumbnail. - float width, height; + float maxWidth, maxHeight; if (orientation == 90 || orientation == 270) { - width = mImageMaxWidthPortrait; - height = mImageMaxHeightPortrait; + maxWidth = mImageMaxWidthPortrait; + maxHeight = mImageMaxHeightPortrait; } else { - width = mImageMaxWidthLandscape; - height = mImageMaxHeightLandscape; + maxWidth = mImageMaxWidthLandscape; + maxHeight = mImageMaxHeightLandscape; } + float actualAspect = maxWidth / maxHeight; + float desiredAspect = (float) mBitmapWidth / mBitmapHeight; + LayoutParams params = mThumbnail.getLayoutParams(); - if (width * mBitmapHeight > height * mBitmapWidth) { - params.width = Math.round(mBitmapWidth * height / mBitmapHeight); - params.height = Math.round(height); + if (actualAspect > desiredAspect) { + params.width = Math.round(maxHeight * desiredAspect); + params.height = Math.round(maxHeight); } else { - params.width = Math.round(width); - params.height = Math.round(mBitmapHeight * params.width / mBitmapWidth); + params.width = Math.round(maxWidth); + params.height = Math.round(maxWidth / desiredAspect); } mThumbnail.setLayoutParams(params); - mRotateLayout.setOrientation(orientation); + + // Calculate the width of the share application list. + LayoutParams shareListParams = mShareView.getLayoutParams(); + if ((orientation == 90 || orientation == 270)) { + shareListParams.width = params.width; + } else { + shareListParams.width = (int) mShareListWidthLandscape; + } + mShareView.setLayoutParams(shareListParams); + if (mShareViewRotateLayout != null) mShareViewRotateLayout.setOrientation(orientation); + if (mThumbnailRotateLayout != null) mThumbnailRotateLayout.setOrientation(orientation); } @Override public void onClick(View v) { switch (v.getId()) { - case R.id.expanded_thumbnail: + case R.id.thumbnail: Util.viewUri(mUri, mContext); break; + case R.id.collapse_button: + dismiss(); + break; } } @@ -140,4 +191,42 @@ public class SharePopup extends PopupWindow implements View.OnClickListener, } return false; } + + public void createShareMenu() { + PackageManager packageManager = mContext.getPackageManager(); + List<ResolveInfo> infos; + infos = packageManager.queryIntentActivities( + new Intent(Intent.ACTION_SEND).setType(mMimeType), 0); + + ArrayList<HashMap<String, Object>> listItem = + new ArrayList<HashMap<String, Object>>(); + for(ResolveInfo info: infos) { + String label = info.loadLabel(packageManager).toString(); + ComponentName component = new ComponentName( + info.activityInfo.packageName, info.activityInfo.name); + HashMap<String, Object> map = new HashMap<String, Object>(); + map.put("text", label); + listItem.add(map); + mComponent.add(component); + } + SimpleAdapter listItemAdapter = new SimpleAdapter(mContext, listItem, + R.layout.share_item, + new String[] {"text"}, + new int[] {R.id.text}); + mShareList.setAdapter(listItemAdapter); + mShareList.setOnItemClickListener(this); + } + + public Uri getUri() { + return mUri; + } + + @Override + public void onItemClick(AdapterView<?> parent, View view, int index, long id) { + Intent intent = new Intent(Intent.ACTION_SEND); + intent.setType(mMimeType); + intent.putExtra(Intent.EXTRA_STREAM, mUri); + intent.setComponent(mComponent.get(index)); + mContext.startActivity(intent); + } } |