am 1ec737ce: Merge "Fix NPE in MessageViewFragmentBase" into honeycomb

* commit '1ec737ce284526a19928bd68275fd37d237bf830':
  Fix NPE in MessageViewFragmentBase
This commit is contained in:
Makoto Onuki 2011-01-13 13:53:25 -08:00 committed by Android Git Automerger
commit 175ec279a4
2 changed files with 13 additions and 8 deletions

View File

@ -55,7 +55,6 @@ public class Preferences {
public static final int TEXT_ZOOM_HUGE = 4; public static final int TEXT_ZOOM_HUGE = 4;
// "normal" will be the default // "normal" will be the default
public static final int TEXT_ZOOM_DEFAULT = TEXT_ZOOM_NORMAL; public static final int TEXT_ZOOM_DEFAULT = TEXT_ZOOM_NORMAL;
public static final float[] TEXT_ZOOM_ARRAY = new float[] {0.8f, 0.9f, 1.0f, 1.2f, 1.5f};
private static Preferences sPreferences; private static Preferences sPreferences;

View File

@ -204,6 +204,12 @@ public abstract class MessageViewFragmentBase extends Fragment implements View.O
*/ */
private int mCurrentTab; private int mCurrentTab;
/**
* Zoom scales for webview. Values correspond to {@link Preferences#TEXT_ZOOM_TINY}..
* {@link Preferences#TEXT_ZOOM_HUGE}.
*/
private static final float[] ZOOM_SCALE_ARRAY = new float[] {0.8f, 0.9f, 1.0f, 1.2f, 1.5f};
/** /**
* Encapsulates known information about a single attachment. * Encapsulates known information about a single attachment.
* *
@ -504,7 +510,7 @@ public abstract class MessageViewFragmentBase extends Fragment implements View.O
// Dynamic configuration of WebView // Dynamic configuration of WebView
final WebSettings settings = mMessageContentView.getSettings(); final WebSettings settings = mMessageContentView.getSettings();
settings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NORMAL); settings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NORMAL);
setTextZoom(); mMessageContentView.setInitialScale(getWebViewZoom());
} }
mAttachmentsScroll.scrollTo(0, 0); mAttachmentsScroll.scrollTo(0, 0);
mInviteScroll.scrollTo(0, 0); mInviteScroll.scrollTo(0, 0);
@ -514,17 +520,15 @@ public abstract class MessageViewFragmentBase extends Fragment implements View.O
} }
/** /**
* Sets the zoom value which is a combination of the user setting * Returns the zoom scale (in percent) which is a combination of the user setting
* (tiny, small, normal, large, huge) and the device density. The intention * (tiny, small, normal, large, huge) and the device density. The intention
* is for the text to be physically equal in size over different density * is for the text to be physically equal in size over different density
* screens. * screens.
*/ */
private void setTextZoom() { private int getWebViewZoom() {
float density = mContext.getResources().getDisplayMetrics().density; float density = mContext.getResources().getDisplayMetrics().density;
int zoom = Preferences.getPreferences(mContext).getTextZoom(); int zoom = Preferences.getPreferences(mContext).getTextZoom();
float textZoom = Preferences.TEXT_ZOOM_ARRAY[zoom] * density; return (int) (ZOOM_SCALE_ARRAY[zoom] * density * 100);
mMessageContentView.setInitialScale((int) (textZoom * 100));
} }
private void initContactStatusViews() { private void initContactStatusViews() {
@ -590,7 +594,9 @@ public abstract class MessageViewFragmentBase extends Fragment implements View.O
*/ */
private void setCurrentTab(int tab) { private void setCurrentTab(int tab) {
mCurrentTab = tab; mCurrentTab = tab;
makeVisible(mMessageContentView, tab == TAB_MESSAGE); if (mMessageContentView != null) {
makeVisible(mMessageContentView, tab == TAB_MESSAGE);
}
mMessageTab.setSelected(tab == TAB_MESSAGE); mMessageTab.setSelected(tab == TAB_MESSAGE);
makeVisible(mAttachmentsScroll, tab == TAB_ATTACHMENT); makeVisible(mAttachmentsScroll, tab == TAB_ATTACHMENT);