Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 package org.chromium.content_shell; | 5 package org.chromium.content_shell; |
| 6 | 6 |
| 7 import android.content.Context; | 7 import android.content.Context; |
| 8 import android.util.AttributeSet; | 8 import android.util.AttributeSet; |
| 9 import android.view.LayoutInflater; | 9 import android.view.LayoutInflater; |
| 10 import android.widget.FrameLayout; | 10 import android.widget.FrameLayout; |
| 11 | 11 |
| 12 import org.chromium.base.CalledByNative; | 12 import org.chromium.base.CalledByNative; |
| 13 import org.chromium.base.JNINamespace; | 13 import org.chromium.base.JNINamespace; |
| 14 import org.chromium.base.ThreadUtils; | 14 import org.chromium.base.ThreadUtils; |
| 15 import org.chromium.content.browser.ContentView; | 15 import org.chromium.content.browser.ContentView; |
| 16 import org.chromium.content.browser.ContentViewClient; | |
| 16 import org.chromium.content.browser.ContentViewRenderView; | 17 import org.chromium.content.browser.ContentViewRenderView; |
| 17 import org.chromium.ui.base.WindowAndroid; | 18 import org.chromium.ui.base.WindowAndroid; |
| 18 | 19 |
| 19 /** | 20 /** |
| 20 * Container and generator of ShellViews. | 21 * Container and generator of ShellViews. |
| 21 */ | 22 */ |
| 22 @JNINamespace("content") | 23 @JNINamespace("content") |
| 23 public class ShellManager extends FrameLayout { | 24 public class ShellManager extends FrameLayout { |
| 24 | 25 |
| 25 public static final String DEFAULT_SHELL_URL = "http://www.google.com"; | 26 public static final String DEFAULT_SHELL_URL = "http://www.google.com"; |
| 26 private static boolean sStartup = true; | 27 private static boolean sStartup = true; |
| 27 private WindowAndroid mWindow; | 28 private WindowAndroid mWindow; |
| 28 private Shell mActiveShell; | 29 private Shell mActiveShell; |
| 29 | 30 |
| 30 private String mStartupUrl = DEFAULT_SHELL_URL; | 31 private String mStartupUrl = DEFAULT_SHELL_URL; |
| 31 | 32 |
| 32 // The target for all content rendering. | 33 // The target for all content rendering. |
| 33 private ContentViewRenderView mContentViewRenderView; | 34 private ContentViewRenderView mContentViewRenderView; |
| 35 private ContentViewClient mContentViewClient; | |
| 34 | 36 |
| 35 /** | 37 /** |
| 36 * Constructor for inflating via XML. | 38 * Constructor for inflating via XML. |
| 37 */ | 39 */ |
| 38 public ShellManager(Context context, AttributeSet attrs) { | 40 public ShellManager(Context context, AttributeSet attrs) { |
| 39 super(context, attrs); | 41 super(context, attrs); |
| 40 nativeInit(this); | 42 nativeInit(this); |
| 41 } | 43 } |
| 42 | 44 |
| 43 /** | 45 /** |
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 91 | 93 |
| 92 /** | 94 /** |
| 93 * Enter or leave overlay video mode. | 95 * Enter or leave overlay video mode. |
| 94 * @param enabled Whether overlay mode is enabled. | 96 * @param enabled Whether overlay mode is enabled. |
| 95 */ | 97 */ |
| 96 public void setOverlayVideoMode(boolean enabled) { | 98 public void setOverlayVideoMode(boolean enabled) { |
| 97 if (mContentViewRenderView == null) return; | 99 if (mContentViewRenderView == null) return; |
| 98 mContentViewRenderView.setOverlayVideoMode(enabled); | 100 mContentViewRenderView.setOverlayVideoMode(enabled); |
| 99 } | 101 } |
| 100 | 102 |
| 103 public void setContentViewClient(ContentViewClient client) { | |
|
Ted C
2014/02/20 00:54:08
I would just have ShellManager build the ContentVi
| |
| 104 mContentViewClient = client; | |
| 105 } | |
| 106 | |
| 101 @SuppressWarnings("unused") | 107 @SuppressWarnings("unused") |
| 102 @CalledByNative | 108 @CalledByNative |
| 103 private Object createShell(long nativeShellPtr) { | 109 private Object createShell(long nativeShellPtr) { |
| 104 assert mContentViewRenderView != null; | 110 assert mContentViewRenderView != null; |
| 105 LayoutInflater inflater = | 111 LayoutInflater inflater = |
| 106 (LayoutInflater) getContext().getSystemService(Context.LAYOUT_IN FLATER_SERVICE); | 112 (LayoutInflater) getContext().getSystemService(Context.LAYOUT_IN FLATER_SERVICE); |
| 107 Shell shellView = (Shell) inflater.inflate(R.layout.shell_view, null); | 113 Shell shellView = (Shell) inflater.inflate(R.layout.shell_view, null); |
| 108 shellView.initialize(nativeShellPtr, mWindow); | 114 shellView.initialize(nativeShellPtr, mWindow); |
| 115 shellView.setContentViewClient(mContentViewClient); | |
|
Ted C
2014/02/20 00:54:08
just pass this param with initialize above.
| |
| 109 | 116 |
| 110 // TODO(tedchoc): Allow switching back to these inactive shells. | 117 // TODO(tedchoc): Allow switching back to these inactive shells. |
| 111 if (mActiveShell != null) removeShell(mActiveShell); | 118 if (mActiveShell != null) removeShell(mActiveShell); |
| 112 | 119 |
| 113 showShell(shellView); | 120 showShell(shellView); |
| 114 return shellView; | 121 return shellView; |
| 115 } | 122 } |
| 116 | 123 |
| 117 private void showShell(Shell shellView) { | 124 private void showShell(Shell shellView) { |
| 118 shellView.setContentViewRenderView(mContentViewRenderView); | 125 shellView.setContentViewRenderView(mContentViewRenderView); |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 132 if (shellView.getParent() == null) return; | 139 if (shellView.getParent() == null) return; |
| 133 ContentView contentView = shellView.getContentView(); | 140 ContentView contentView = shellView.getContentView(); |
| 134 if (contentView != null) contentView.onHide(); | 141 if (contentView != null) contentView.onHide(); |
| 135 shellView.setContentViewRenderView(null); | 142 shellView.setContentViewRenderView(null); |
| 136 removeView(shellView); | 143 removeView(shellView); |
| 137 } | 144 } |
| 138 | 145 |
| 139 private static native void nativeInit(Object shellManagerInstance); | 146 private static native void nativeInit(Object shellManagerInstance); |
| 140 private static native void nativeLaunchShell(String url); | 147 private static native void nativeLaunchShell(String url); |
| 141 } | 148 } |
| OLD | NEW |