diff options
author | Svetoslav <svetoslavganov@google.com> | 2014-09-09 22:11:10 -0700 |
---|---|---|
committer | Svetoslav <svetoslavganov@google.com> | 2014-09-10 11:54:37 -0700 |
commit | e652b02d45bbda11c9cb8f663fa7f25903b90225 (patch) | |
tree | 4f5d41fd4300e01538444c5b4c1ce831ba5cf2cd /packages/PrintSpooler/src | |
parent | cd7955f66c3b1c47b477ae197ec15c586cec784e (diff) | |
download | frameworks_base-e652b02d45bbda11c9cb8f663fa7f25903b90225.zip frameworks_base-e652b02d45bbda11c9cb8f663fa7f25903b90225.tar.gz frameworks_base-e652b02d45bbda11c9cb8f663fa7f25903b90225.tar.bz2 |
Accessibilty support for the print UI.
bug:15816751
Change-Id: I5dcdbdd0357843b870ddd47d7c41cfba114d194c
Diffstat (limited to 'packages/PrintSpooler/src')
5 files changed, 135 insertions, 44 deletions
diff --git a/packages/PrintSpooler/src/com/android/printspooler/ui/PageAdapter.java b/packages/PrintSpooler/src/com/android/printspooler/ui/PageAdapter.java index ce0b9b6..25bdb12 100644 --- a/packages/PrintSpooler/src/com/android/printspooler/ui/PageAdapter.java +++ b/packages/PrintSpooler/src/com/android/printspooler/ui/PageAdapter.java @@ -41,6 +41,7 @@ import com.android.printspooler.model.PageContentRepository; import com.android.printspooler.model.PageContentRepository.PageContentProvider; import com.android.printspooler.util.PageRangeUtils; import com.android.printspooler.widget.PageContentView; +import com.android.printspooler.widget.PreviewPageFrame; import dalvik.system.CloseGuard; import java.util.ArrayList; @@ -94,12 +95,6 @@ public final class PageAdapter extends Adapter implements private int mDocumentPageCount = PrintDocumentInfo.PAGE_COUNT_UNKNOWN; private int mSelectedPageCount; - private float mSelectedPageElevation; - private float mSelectedPageAlpha; - - private float mUnselectedPageElevation; - private float mUnselectedPageAlpha; - private int mPreviewPageMargin; private int mPreviewPageMinWidth; private int mPreviewListPadding; @@ -134,16 +129,6 @@ public final class PageAdapter extends Adapter implements Context.LAYOUT_INFLATER_SERVICE); mPageContentRepository = new PageContentRepository(context, this); - mSelectedPageElevation = mContext.getResources().getDimension( - R.dimen.selected_page_elevation); - mSelectedPageAlpha = mContext.getResources().getFraction( - R.fraction.page_selected_alpha, 1, 1); - - mUnselectedPageElevation = mContext.getResources().getDimension( - R.dimen.unselected_page_elevation); - mUnselectedPageAlpha = mContext.getResources().getFraction( - R.fraction.page_unselected_alpha, 1, 1); - mPreviewPageMargin = mContext.getResources().getDimensionPixelSize( R.dimen.preview_page_margin); @@ -296,7 +281,7 @@ public final class PageAdapter extends Adapter implements MyViewHolder myHolder = (MyViewHolder) holder; - View page = holder.itemView; + PreviewPageFrame page = (PreviewPageFrame) holder.itemView; page.setOnClickListener(mPageClickListener); page.setTag(holder); @@ -340,20 +325,15 @@ public final class PageAdapter extends Adapter implements } content.init(provider, mEmptyState, mMediaSize, mMinMargins); - View pageSelector = page.findViewById(R.id.page_selector); - pageSelector.setTag(myHolder); - pageSelector.setOnClickListener(mPageClickListener); - if (mConfirmedPagesInDocument.indexOfKey(pageInDocument) >= 0) { - pageSelector.setSelected(true); - page.setTranslationZ(mSelectedPageElevation); - page.setAlpha(mSelectedPageAlpha); + page.setSelected(true, false); } else { - pageSelector.setSelected(false); - page.setTranslationZ(mUnselectedPageElevation); - page.setAlpha(mUnselectedPageAlpha); + page.setSelected(false, false); } + page.setContentDescription(mContext.getString(R.string.page_description_template, + pageInDocument + 1, mDocumentPageCount)); + TextView pageNumberView = (TextView) page.findViewById(R.id.page_number); String text = mContext.getString(R.string.current_page_template, pageInDocument + 1, mDocumentPageCount); @@ -792,24 +772,20 @@ public final class PageAdapter extends Adapter implements private final class PageClickListener implements OnClickListener { @Override - public void onClick(View page) { + public void onClick(View view) { + PreviewPageFrame page = (PreviewPageFrame) view; MyViewHolder holder = (MyViewHolder) page.getTag(); final int pageInAdapter = holder.mPageInAdapter; final int pageInDocument = computePageIndexInDocument(pageInAdapter); - View pageSelector = page.findViewById(R.id.page_selector); if (mConfirmedPagesInDocument.indexOfKey(pageInDocument) < 0) { mConfirmedPagesInDocument.put(pageInDocument, null); - pageSelector.setSelected(true); - page.animate().translationZ(mSelectedPageElevation) - .alpha(mSelectedPageAlpha); + page.setSelected(true, true); } else { if (mConfirmedPagesInDocument.size() <= 1) { return; } mConfirmedPagesInDocument.remove(pageInDocument); - pageSelector.setSelected(false); - page.animate().translationZ(mUnselectedPageElevation) - .alpha(mUnselectedPageAlpha); + page.setSelected(false, true); } } } diff --git a/packages/PrintSpooler/src/com/android/printspooler/ui/PrintActivity.java b/packages/PrintSpooler/src/com/android/printspooler/ui/PrintActivity.java index c517f2d..4b58855 100644 --- a/packages/PrintSpooler/src/com/android/printspooler/ui/PrintActivity.java +++ b/packages/PrintSpooler/src/com/android/printspooler/ui/PrintActivity.java @@ -61,6 +61,7 @@ import android.view.View; import android.view.View.OnClickListener; import android.view.View.OnFocusChangeListener; import android.view.ViewGroup; +import android.view.accessibility.AccessibilityEvent; import android.view.inputmethod.InputMethodManager; import android.widget.AdapterView; import android.widget.AdapterView.OnItemSelectedListener; @@ -191,6 +192,7 @@ public class PrintActivity extends Activity implements RemotePrintDocument.Updat private PrintContentView mOptionsContent; + private View mSummaryContainer; private TextView mSummaryCopies; private TextView mSummaryPaperSize; @@ -983,6 +985,7 @@ public class PrintActivity extends Activity implements RemotePrintDocument.Updat private void bindUi() { // Summary + mSummaryContainer = findViewById(R.id.summary_content); mSummaryCopies = (TextView) findViewById(R.id.copies_count_summary); mSummaryPaperSize = (TextView) findViewById(R.id.paper_size_summary); @@ -1081,15 +1084,7 @@ public class PrintActivity extends Activity implements RemotePrintDocument.Updat void updateOptionsUi() { // Always update the summary. - if (!TextUtils.isEmpty(mCopiesEditText.getText())) { - mSummaryCopies.setText(mCopiesEditText.getText()); - } - - final int selectedMediaIndex = mMediaSizeSpinner.getSelectedItemPosition(); - if (selectedMediaIndex >= 0) { - SpinnerItem<MediaSize> mediaItem = mMediaSizeSpinnerAdapter.getItem(selectedMediaIndex); - mSummaryPaperSize.setText(mediaItem.label); - } + updateSummary(); if (mState == STATE_PRINT_CONFIRMED || mState == STATE_PRINT_COMPLETED @@ -1330,8 +1325,10 @@ public class PrintActivity extends Activity implements RemotePrintDocument.Updat // Print if (mDestinationSpinnerAdapter.getPdfPrinter() != mCurrentPrinter) { mPrintButton.setImageResource(com.android.internal.R.drawable.ic_print); + mPrintButton.setContentDescription(getString(R.string.print_button)); } else { mPrintButton.setImageResource(R.drawable.ic_menu_savetopdf); + mPrintButton.setContentDescription(getString(R.string.savetopdf_button)); } if ((mRangeOptionsSpinner.getSelectedItemPosition() == 1 && (TextUtils.isEmpty(mPageRangeEditText.getText()) || hasErrors())) @@ -1357,6 +1354,28 @@ public class PrintActivity extends Activity implements RemotePrintDocument.Updat } } + private void updateSummary() { + CharSequence copiesText = null; + CharSequence mediaSizeText = null; + + if (!TextUtils.isEmpty(mCopiesEditText.getText())) { + copiesText = mCopiesEditText.getText(); + mSummaryCopies.setText(copiesText); + } + + final int selectedMediaIndex = mMediaSizeSpinner.getSelectedItemPosition(); + if (selectedMediaIndex >= 0) { + SpinnerItem<MediaSize> mediaItem = mMediaSizeSpinnerAdapter.getItem(selectedMediaIndex); + mediaSizeText = mediaItem.label; + mSummaryPaperSize.setText(mediaSizeText); + } + + if (!TextUtils.isEmpty(copiesText) && !TextUtils.isEmpty(mediaSizeText)) { + String summaryText = getString(R.string.summary_template, copiesText, mediaSizeText); + mSummaryContainer.setContentDescription(summaryText); + } + } + private void updatePageRangeOptions(int pageCount) { ArrayAdapter<SpinnerItem<Integer>> rangeOptionsSpinnerAdapter = (ArrayAdapter) mRangeOptionsSpinner.getAdapter(); diff --git a/packages/PrintSpooler/src/com/android/printspooler/widget/PageContentView.java b/packages/PrintSpooler/src/com/android/printspooler/widget/PageContentView.java index e2ae758..c22c0e2 100644 --- a/packages/PrintSpooler/src/com/android/printspooler/widget/PageContentView.java +++ b/packages/PrintSpooler/src/com/android/printspooler/widget/PageContentView.java @@ -35,6 +35,7 @@ import com.android.printspooler.model.PageContentRepository.PageContentProvider; */ public class PageContentView extends View implements PageContentRepository.OnPageContentAvailableCallback { + private PageContentProvider mProvider; private MediaSize mMediaSize; diff --git a/packages/PrintSpooler/src/com/android/printspooler/widget/PreviewPageFrame.java b/packages/PrintSpooler/src/com/android/printspooler/widget/PreviewPageFrame.java new file mode 100644 index 0000000..feb0316 --- /dev/null +++ b/packages/PrintSpooler/src/com/android/printspooler/widget/PreviewPageFrame.java @@ -0,0 +1,89 @@ +/* + * Copyright (C) 2014 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.android.printspooler.widget; + +import android.content.Context; +import android.util.AttributeSet; +import android.view.accessibility.AccessibilityEvent; +import android.view.accessibility.AccessibilityNodeInfo; +import android.widget.CompoundButton; +import android.widget.LinearLayout; +import com.android.printspooler.R; + +/** + * This class represents the frame of page in the print preview list + * that contains the page and a footer. + */ +public final class PreviewPageFrame extends LinearLayout { + private final float mSelectedElevation; + private final float mNotSelectedElevation; + + private final float mSelectedPageAlpha; + private final float mNotSelectedAlpha; + + public PreviewPageFrame(Context context, AttributeSet attrs) { + super(context, attrs); + mSelectedElevation = mContext.getResources().getDimension( + R.dimen.selected_page_elevation); + mNotSelectedElevation = mContext.getResources().getDimension( + R.dimen.unselected_page_elevation); + mSelectedPageAlpha = mContext.getResources().getFraction( + R.fraction.page_selected_alpha, 1, 1); + mNotSelectedAlpha = mContext.getResources().getFraction( + R.fraction.page_unselected_alpha, 1, 1); + } + + @Override + public void onInitializeAccessibilityEvent(AccessibilityEvent event) { + super.onInitializeAccessibilityEvent(event); + event.setClassName(CompoundButton.class.getName()); + event.setChecked(isSelected()); + } + + @Override + public void onInitializeAccessibilityNodeInfo(AccessibilityNodeInfo info) { + super.onInitializeAccessibilityNodeInfo(info); + info.setClassName(CompoundButton.class.getName()); + info.setSelected(false); + info.setCheckable(true); + info.setChecked(isSelected()); + } + + public void setSelected(boolean selected, boolean animate) { + if (isSelected() == selected) { + return; + } + setSelected(selected); + if (selected) { + if (animate) { + animate().translationZ(mSelectedElevation) + .alpha(mSelectedPageAlpha); + } else { + setTranslationZ(mSelectedElevation); + setAlpha(mSelectedPageAlpha); + } + } else { + if (animate) { + animate().translationZ(mNotSelectedElevation) + .alpha(mNotSelectedAlpha); + } else { + setTranslationZ(mNotSelectedElevation); + setAlpha(mNotSelectedAlpha); + } + } + } +} diff --git a/packages/PrintSpooler/src/com/android/printspooler/widget/PrintContentView.java b/packages/PrintSpooler/src/com/android/printspooler/widget/PrintContentView.java index c84b06a..f6c06a2 100644 --- a/packages/PrintSpooler/src/com/android/printspooler/widget/PrintContentView.java +++ b/packages/PrintSpooler/src/com/android/printspooler/widget/PrintContentView.java @@ -336,6 +336,9 @@ public final class PrintContentView extends ViewGroup implements View.OnClickLis if (mOptionsStateChangeListener != null) { mOptionsStateChangeListener.onOptionsOpened(); } + mExpandCollapseHandle.setContentDescription( + mContext.getString(R.string.collapse_handle)); + announceForAccessibility(mContext.getString(R.string.print_options_expanded)); mSummaryContent.setVisibility(View.GONE); mEmbeddedContentScrim.setOnClickListener(this); mExpandCollapseIcon.setBackgroundResource(R.drawable.ic_expand_less); @@ -347,6 +350,9 @@ public final class PrintContentView extends ViewGroup implements View.OnClickLis if (mOptionsStateChangeListener != null) { mOptionsStateChangeListener.onOptionsClosed(); } + mExpandCollapseHandle.setContentDescription( + mContext.getString(R.string.expand_handle)); + announceForAccessibility(mContext.getString(R.string.print_options_collapsed)); if (mMoreOptionsButton.getVisibility() != View.GONE) { mMoreOptionsButton.setVisibility(View.INVISIBLE); } |