Loading core/java/com/android/internal/widget/MediaNotificationView.java +37 −27 Original line number Original line Diff line number Diff line Loading @@ -21,6 +21,7 @@ import android.content.Context; import android.util.AttributeSet; import android.util.AttributeSet; import android.view.View; import android.view.View; import android.view.ViewGroup; import android.view.ViewGroup; import android.widget.FrameLayout; import android.widget.ImageView; import android.widget.ImageView; import android.widget.RelativeLayout; import android.widget.RelativeLayout; import android.widget.RemoteViews; import android.widget.RemoteViews; Loading @@ -31,16 +32,16 @@ import android.widget.RemoteViews; * @hide * @hide */ */ @RemoteViews.RemoteView @RemoteViews.RemoteView public class MediaNotificationView extends RelativeLayout { public class MediaNotificationView extends FrameLayout { private final int mMaxImageSize; private final int mMaxImageSize; private final int mImageMarginBottom; private final int mImageMinTopMargin; private final int mImageMinTopMargin; private final int mNotificationContentMarginEnd; private final int mNotificationContentMarginEnd; private final int mNotificationContentImageMarginEnd; private final int mNotificationContentImageMarginEnd; private ImageView mRightIcon; private ImageView mRightIcon; private View mActions; private View mActions; private View mHeader; private View mHeader; private View mMainColumn; public MediaNotificationView(Context context) { public MediaNotificationView(Context context) { this(context, null); this(context, null); Loading @@ -61,25 +62,40 @@ public class MediaNotificationView extends RelativeLayout { if (hasIcon && mode != MeasureSpec.UNSPECIFIED) { if (hasIcon && mode != MeasureSpec.UNSPECIFIED) { measureChild(mActions, widthMeasureSpec, heightMeasureSpec); measureChild(mActions, widthMeasureSpec, heightMeasureSpec); int size = MeasureSpec.getSize(widthMeasureSpec); int size = MeasureSpec.getSize(widthMeasureSpec); int height = MeasureSpec.getSize(heightMeasureSpec); size = size - mActions.getMeasuredWidth(); size = size - mActions.getMeasuredWidth(); ViewGroup.MarginLayoutParams layoutParams = ViewGroup.MarginLayoutParams layoutParams = (MarginLayoutParams) mRightIcon.getLayoutParams(); (MarginLayoutParams) mRightIcon.getLayoutParams(); size -= layoutParams.getMarginEnd(); int imageEndMargin = layoutParams.getMarginEnd(); size -= imageEndMargin; size = Math.min(size, mMaxImageSize); size = Math.min(size, mMaxImageSize); size = Math.max(size, mRightIcon.getMinimumWidth()); size = Math.max(size, mRightIcon.getMinimumWidth()); layoutParams.width = size; layoutParams.width = size; layoutParams.height = size; layoutParams.height = size; // because we can't allign it to the bottom with a margin, we add a topmargin to it mRightIcon.setLayoutParams(layoutParams); layoutParams.topMargin = height - size - mImageMarginBottom; // lets ensure that the main column doesn't run into the image ViewGroup.MarginLayoutParams mainParams = (MarginLayoutParams) mMainColumn.getLayoutParams(); int marginEnd = size + imageEndMargin + mNotificationContentMarginEnd; if (marginEnd != mainParams.getMarginEnd()) { mainParams.setMarginEnd(marginEnd); mMainColumn.setLayoutParams(mainParams); } } super.onMeasure(widthMeasureSpec, heightMeasureSpec); ViewGroup.MarginLayoutParams iconParams = (MarginLayoutParams) mRightIcon.getLayoutParams(); int topMargin = getMeasuredHeight() - mRightIcon.getMeasuredHeight() - iconParams.bottomMargin; // If the topMargin is high enough we can also remove the header constraint! // If the topMargin is high enough we can also remove the header constraint! if (layoutParams.topMargin >= mImageMinTopMargin) { if (!hasIcon || topMargin >= mImageMinTopMargin) { resetHeaderIndention(); resetHeaderIndention(); } else { } else { int paddingEnd = mNotificationContentImageMarginEnd; int paddingEnd = mNotificationContentImageMarginEnd; ViewGroup.MarginLayoutParams headerParams = ViewGroup.MarginLayoutParams headerParams = (MarginLayoutParams) mHeader.getLayoutParams(); (MarginLayoutParams) mHeader.getLayoutParams(); headerParams.setMarginEnd(size + layoutParams.getMarginEnd()); headerParams.setMarginEnd(mRightIcon.getMeasuredWidth() + iconParams.getMarginEnd()); if (mHeader.getPaddingEnd() != paddingEnd) { if (mHeader.getPaddingEnd() != paddingEnd) { mHeader.setPadding( mHeader.setPadding( isLayoutRtl() ? paddingEnd : mHeader.getPaddingLeft(), isLayoutRtl() ? paddingEnd : mHeader.getPaddingLeft(), Loading @@ -89,11 +105,6 @@ public class MediaNotificationView extends RelativeLayout { mHeader.setLayoutParams(headerParams); mHeader.setLayoutParams(headerParams); } } } } mRightIcon.setLayoutParams(layoutParams); } else if (!hasIcon && mHeader.getPaddingEnd() != mNotificationContentMarginEnd) { resetHeaderIndention(); } super.onMeasure(widthMeasureSpec, heightMeasureSpec); } } private void resetHeaderIndention() { private void resetHeaderIndention() { Loading @@ -115,8 +126,6 @@ public class MediaNotificationView extends RelativeLayout { super(context, attrs, defStyleAttr, defStyleRes); super(context, attrs, defStyleAttr, defStyleRes); mMaxImageSize = context.getResources().getDimensionPixelSize( mMaxImageSize = context.getResources().getDimensionPixelSize( com.android.internal.R.dimen.media_notification_expanded_image_max_size); com.android.internal.R.dimen.media_notification_expanded_image_max_size); mImageMarginBottom = context.getResources().getDimensionPixelSize( com.android.internal.R.dimen.media_notification_expanded_image_margin_bottom); mImageMinTopMargin = (int) (context.getResources().getDimensionPixelSize( mImageMinTopMargin = (int) (context.getResources().getDimensionPixelSize( com.android.internal.R.dimen.notification_content_margin_top) com.android.internal.R.dimen.notification_content_margin_top) + getResources().getDisplayMetrics().density * 2); + getResources().getDisplayMetrics().density * 2); Loading @@ -132,5 +141,6 @@ public class MediaNotificationView extends RelativeLayout { mRightIcon = (ImageView) findViewById(com.android.internal.R.id.right_icon); mRightIcon = (ImageView) findViewById(com.android.internal.R.id.right_icon); mActions = findViewById(com.android.internal.R.id.media_actions); mActions = findViewById(com.android.internal.R.id.media_actions); mHeader = findViewById(com.android.internal.R.id.notification_header); mHeader = findViewById(com.android.internal.R.id.notification_header); mMainColumn = findViewById(com.android.internal.R.id.notification_main_column); } } } } core/res/res/layout/notification_template_material_big_media.xml +30 −27 Original line number Original line Diff line number Diff line Loading @@ -19,14 +19,19 @@ <com.android.internal.widget.MediaNotificationView xmlns:android="http://schemas.android.com/apk/res/android" <com.android.internal.widget.MediaNotificationView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/status_bar_latest_event_content" android:id="@+id/status_bar_latest_event_content" android:layout_width="match_parent" android:layout_width="match_parent" android:layout_height="126dp" android:layout_height="wrap_content" android:background="#00000000" android:background="#00000000" android:tag="bigMediaNarrow" android:tag="bigMediaNarrow" > > <include layout="@layout/notification_template_header" <include layout="@layout/notification_template_header" android:layout_width="match_parent" android:layout_width="match_parent" android:layout_height="48dp" android:layout_height="48dp" android:layout_alignParentStart="true"/> android:layout_gravity="start"/> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" > <LinearLayout <LinearLayout android:id="@+id/notification_main_column" android:id="@+id/notification_main_column" android:layout_width="match_parent" android:layout_width="match_parent" Loading @@ -35,7 +40,6 @@ android:layout_marginStart="@dimen/notification_content_margin_start" android:layout_marginStart="@dimen/notification_content_margin_start" android:layout_marginBottom="@dimen/notification_content_margin_bottom" android:layout_marginBottom="@dimen/notification_content_margin_bottom" android:layout_marginEnd="@dimen/notification_content_margin_end" android:layout_marginEnd="@dimen/notification_content_margin_end" android:layout_toStartOf="@id/right_icon" android:minHeight="@dimen/notification_min_content_height" android:minHeight="@dimen/notification_min_content_height" android:orientation="vertical" android:orientation="vertical" > > Loading @@ -46,8 +50,7 @@ android:id="@+id/media_actions" android:id="@+id/media_actions" android:layout_width="wrap_content" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:layout_marginTop="-15dp" android:layout_alignParentStart="true" android:paddingStart="8dp" android:paddingStart="8dp" android:paddingBottom="8dp" android:paddingBottom="8dp" android:orientation="horizontal" android:orientation="horizontal" Loading @@ -55,15 +58,15 @@ > > <!-- media buttons will be added here --> <!-- media buttons will be added here --> </LinearLayout> </LinearLayout> </LinearLayout> <ImageView android:id="@+id/right_icon" <ImageView android:id="@+id/right_icon" android:layout_width="@dimen/media_notification_expanded_image_max_size" android:layout_width="@dimen/media_notification_expanded_image_max_size" android:layout_height="@dimen/media_notification_expanded_image_max_size" android:layout_height="@dimen/media_notification_expanded_image_max_size" android:minWidth="40dp" android:minWidth="40dp" android:layout_marginEnd="16dp" android:layout_marginEnd="16dp" android:layout_marginTop="16dp" android:layout_marginBottom="16dp" android:layout_alignParentEnd="true" android:layout_gravity="bottom|end" android:layout_alignParentTop="true" android:scaleType="centerCrop" android:scaleType="centerCrop" /> /> </com.android.internal.widget.MediaNotificationView> </com.android.internal.widget.MediaNotificationView> Loading
core/java/com/android/internal/widget/MediaNotificationView.java +37 −27 Original line number Original line Diff line number Diff line Loading @@ -21,6 +21,7 @@ import android.content.Context; import android.util.AttributeSet; import android.util.AttributeSet; import android.view.View; import android.view.View; import android.view.ViewGroup; import android.view.ViewGroup; import android.widget.FrameLayout; import android.widget.ImageView; import android.widget.ImageView; import android.widget.RelativeLayout; import android.widget.RelativeLayout; import android.widget.RemoteViews; import android.widget.RemoteViews; Loading @@ -31,16 +32,16 @@ import android.widget.RemoteViews; * @hide * @hide */ */ @RemoteViews.RemoteView @RemoteViews.RemoteView public class MediaNotificationView extends RelativeLayout { public class MediaNotificationView extends FrameLayout { private final int mMaxImageSize; private final int mMaxImageSize; private final int mImageMarginBottom; private final int mImageMinTopMargin; private final int mImageMinTopMargin; private final int mNotificationContentMarginEnd; private final int mNotificationContentMarginEnd; private final int mNotificationContentImageMarginEnd; private final int mNotificationContentImageMarginEnd; private ImageView mRightIcon; private ImageView mRightIcon; private View mActions; private View mActions; private View mHeader; private View mHeader; private View mMainColumn; public MediaNotificationView(Context context) { public MediaNotificationView(Context context) { this(context, null); this(context, null); Loading @@ -61,25 +62,40 @@ public class MediaNotificationView extends RelativeLayout { if (hasIcon && mode != MeasureSpec.UNSPECIFIED) { if (hasIcon && mode != MeasureSpec.UNSPECIFIED) { measureChild(mActions, widthMeasureSpec, heightMeasureSpec); measureChild(mActions, widthMeasureSpec, heightMeasureSpec); int size = MeasureSpec.getSize(widthMeasureSpec); int size = MeasureSpec.getSize(widthMeasureSpec); int height = MeasureSpec.getSize(heightMeasureSpec); size = size - mActions.getMeasuredWidth(); size = size - mActions.getMeasuredWidth(); ViewGroup.MarginLayoutParams layoutParams = ViewGroup.MarginLayoutParams layoutParams = (MarginLayoutParams) mRightIcon.getLayoutParams(); (MarginLayoutParams) mRightIcon.getLayoutParams(); size -= layoutParams.getMarginEnd(); int imageEndMargin = layoutParams.getMarginEnd(); size -= imageEndMargin; size = Math.min(size, mMaxImageSize); size = Math.min(size, mMaxImageSize); size = Math.max(size, mRightIcon.getMinimumWidth()); size = Math.max(size, mRightIcon.getMinimumWidth()); layoutParams.width = size; layoutParams.width = size; layoutParams.height = size; layoutParams.height = size; // because we can't allign it to the bottom with a margin, we add a topmargin to it mRightIcon.setLayoutParams(layoutParams); layoutParams.topMargin = height - size - mImageMarginBottom; // lets ensure that the main column doesn't run into the image ViewGroup.MarginLayoutParams mainParams = (MarginLayoutParams) mMainColumn.getLayoutParams(); int marginEnd = size + imageEndMargin + mNotificationContentMarginEnd; if (marginEnd != mainParams.getMarginEnd()) { mainParams.setMarginEnd(marginEnd); mMainColumn.setLayoutParams(mainParams); } } super.onMeasure(widthMeasureSpec, heightMeasureSpec); ViewGroup.MarginLayoutParams iconParams = (MarginLayoutParams) mRightIcon.getLayoutParams(); int topMargin = getMeasuredHeight() - mRightIcon.getMeasuredHeight() - iconParams.bottomMargin; // If the topMargin is high enough we can also remove the header constraint! // If the topMargin is high enough we can also remove the header constraint! if (layoutParams.topMargin >= mImageMinTopMargin) { if (!hasIcon || topMargin >= mImageMinTopMargin) { resetHeaderIndention(); resetHeaderIndention(); } else { } else { int paddingEnd = mNotificationContentImageMarginEnd; int paddingEnd = mNotificationContentImageMarginEnd; ViewGroup.MarginLayoutParams headerParams = ViewGroup.MarginLayoutParams headerParams = (MarginLayoutParams) mHeader.getLayoutParams(); (MarginLayoutParams) mHeader.getLayoutParams(); headerParams.setMarginEnd(size + layoutParams.getMarginEnd()); headerParams.setMarginEnd(mRightIcon.getMeasuredWidth() + iconParams.getMarginEnd()); if (mHeader.getPaddingEnd() != paddingEnd) { if (mHeader.getPaddingEnd() != paddingEnd) { mHeader.setPadding( mHeader.setPadding( isLayoutRtl() ? paddingEnd : mHeader.getPaddingLeft(), isLayoutRtl() ? paddingEnd : mHeader.getPaddingLeft(), Loading @@ -89,11 +105,6 @@ public class MediaNotificationView extends RelativeLayout { mHeader.setLayoutParams(headerParams); mHeader.setLayoutParams(headerParams); } } } } mRightIcon.setLayoutParams(layoutParams); } else if (!hasIcon && mHeader.getPaddingEnd() != mNotificationContentMarginEnd) { resetHeaderIndention(); } super.onMeasure(widthMeasureSpec, heightMeasureSpec); } } private void resetHeaderIndention() { private void resetHeaderIndention() { Loading @@ -115,8 +126,6 @@ public class MediaNotificationView extends RelativeLayout { super(context, attrs, defStyleAttr, defStyleRes); super(context, attrs, defStyleAttr, defStyleRes); mMaxImageSize = context.getResources().getDimensionPixelSize( mMaxImageSize = context.getResources().getDimensionPixelSize( com.android.internal.R.dimen.media_notification_expanded_image_max_size); com.android.internal.R.dimen.media_notification_expanded_image_max_size); mImageMarginBottom = context.getResources().getDimensionPixelSize( com.android.internal.R.dimen.media_notification_expanded_image_margin_bottom); mImageMinTopMargin = (int) (context.getResources().getDimensionPixelSize( mImageMinTopMargin = (int) (context.getResources().getDimensionPixelSize( com.android.internal.R.dimen.notification_content_margin_top) com.android.internal.R.dimen.notification_content_margin_top) + getResources().getDisplayMetrics().density * 2); + getResources().getDisplayMetrics().density * 2); Loading @@ -132,5 +141,6 @@ public class MediaNotificationView extends RelativeLayout { mRightIcon = (ImageView) findViewById(com.android.internal.R.id.right_icon); mRightIcon = (ImageView) findViewById(com.android.internal.R.id.right_icon); mActions = findViewById(com.android.internal.R.id.media_actions); mActions = findViewById(com.android.internal.R.id.media_actions); mHeader = findViewById(com.android.internal.R.id.notification_header); mHeader = findViewById(com.android.internal.R.id.notification_header); mMainColumn = findViewById(com.android.internal.R.id.notification_main_column); } } } }
core/res/res/layout/notification_template_material_big_media.xml +30 −27 Original line number Original line Diff line number Diff line Loading @@ -19,14 +19,19 @@ <com.android.internal.widget.MediaNotificationView xmlns:android="http://schemas.android.com/apk/res/android" <com.android.internal.widget.MediaNotificationView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/status_bar_latest_event_content" android:id="@+id/status_bar_latest_event_content" android:layout_width="match_parent" android:layout_width="match_parent" android:layout_height="126dp" android:layout_height="wrap_content" android:background="#00000000" android:background="#00000000" android:tag="bigMediaNarrow" android:tag="bigMediaNarrow" > > <include layout="@layout/notification_template_header" <include layout="@layout/notification_template_header" android:layout_width="match_parent" android:layout_width="match_parent" android:layout_height="48dp" android:layout_height="48dp" android:layout_alignParentStart="true"/> android:layout_gravity="start"/> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" > <LinearLayout <LinearLayout android:id="@+id/notification_main_column" android:id="@+id/notification_main_column" android:layout_width="match_parent" android:layout_width="match_parent" Loading @@ -35,7 +40,6 @@ android:layout_marginStart="@dimen/notification_content_margin_start" android:layout_marginStart="@dimen/notification_content_margin_start" android:layout_marginBottom="@dimen/notification_content_margin_bottom" android:layout_marginBottom="@dimen/notification_content_margin_bottom" android:layout_marginEnd="@dimen/notification_content_margin_end" android:layout_marginEnd="@dimen/notification_content_margin_end" android:layout_toStartOf="@id/right_icon" android:minHeight="@dimen/notification_min_content_height" android:minHeight="@dimen/notification_min_content_height" android:orientation="vertical" android:orientation="vertical" > > Loading @@ -46,8 +50,7 @@ android:id="@+id/media_actions" android:id="@+id/media_actions" android:layout_width="wrap_content" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:layout_marginTop="-15dp" android:layout_alignParentStart="true" android:paddingStart="8dp" android:paddingStart="8dp" android:paddingBottom="8dp" android:paddingBottom="8dp" android:orientation="horizontal" android:orientation="horizontal" Loading @@ -55,15 +58,15 @@ > > <!-- media buttons will be added here --> <!-- media buttons will be added here --> </LinearLayout> </LinearLayout> </LinearLayout> <ImageView android:id="@+id/right_icon" <ImageView android:id="@+id/right_icon" android:layout_width="@dimen/media_notification_expanded_image_max_size" android:layout_width="@dimen/media_notification_expanded_image_max_size" android:layout_height="@dimen/media_notification_expanded_image_max_size" android:layout_height="@dimen/media_notification_expanded_image_max_size" android:minWidth="40dp" android:minWidth="40dp" android:layout_marginEnd="16dp" android:layout_marginEnd="16dp" android:layout_marginTop="16dp" android:layout_marginBottom="16dp" android:layout_alignParentEnd="true" android:layout_gravity="bottom|end" android:layout_alignParentTop="true" android:scaleType="centerCrop" android:scaleType="centerCrop" /> /> </com.android.internal.widget.MediaNotificationView> </com.android.internal.widget.MediaNotificationView>