直到现在,我还只是一名iPhone开发人员,而现在,我决定让Android焕然一新。我无法在Android上弄清楚的是如何以编程方式防止滚动WebView
?
类似于iPhone的onTouchMove
事件预防措施将是很棒的!
Answers:
这是我的代码,用于禁用webview中的所有滚动:
// disable scroll on touch
webview.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
return (event.getAction() == MotionEvent.ACTION_MOVE);
}
});
要仅隐藏滚动条,而不禁用滚动,请执行以下操作:
WebView.setVerticalScrollBarEnabled(false);
WebView.setHorizontalScrollBarEnabled(false);
或者您可以尝试使用单列布局,但这仅适用于简单页面,并且会禁用水平滚动:
//Only disabled the horizontal scrolling:
webview.getSettings().setLayoutAlgorithm(LayoutAlgorithm.SINGLE_COLUMN);
您还可以尝试使用垂直滚动的scrollview来包装webview并禁用该webview上的所有滚动:
<ScrollView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:scrollbars="vertical" >
<WebView
android:id="@+id/mywebview"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:scrollbars="none" />
</ScrollView>
并设置
webview.setScrollContainer(false);
不要忘记添加webview.setOnTouchListener(...)
上面的代码以禁用Web视图中的所有滚动。垂直的ScrollView将允许滚动WebView的内容。
MotionEvent.ACTION_MOVE
事件,WebView
请在下面查看我的答案。
ACTION_MOVE
onsetOnTouchListener
事件会产生一些副作用,因此我不建议您使用此答案。1.快速滑动将被视为onclick
页面事件。2.防止页面上元素的溢出滚动,这可能需要适当的交互,具体取决于站点。3. JStouchmove
事件。@GDanger具有正确的答案,可以overScrollBy
通过扩展来覆盖,WebView
因为它没有其他副作用,只是防止了页面滚动。stackoverflow.com/a/26129301/1244574
我不知道您是否仍然需要它,但是这里是解决方案:
appView = (WebView) findViewById(R.id.appView);
appView.setVerticalScrollBarEnabled(false);
appView.setHorizontalScrollBarEnabled(false);
进行WebView
忽略运动事件是错误的处理方法。如果WebView
需要了解这些事件怎么办?
而是继承WebView
并重写非私有滚动方法。
public class NoScrollWebView extends WebView {
...
@Override
public boolean overScrollBy(int deltaX, int deltaY, int scrollX, int scrollY,
int scrollRangeX, int scrollRangeY, int maxOverScrollX,
int maxOverScrollY, boolean isTouchEvent) {
return false;
}
@Override
public void scrollTo(int x, int y) {
// Do nothing
}
@Override
public void computeScroll() {
// Do nothing
}
}
如果你看一下源为WebView
您可以看到onTouchEvent
来电doDrag
这就要求overScrollBy。
如果内容正确包装,则在正文中添加边距详细信息将防止滚动,如下所示:
<body leftmargin="0" topmargin="0" rightmargin="0" bottommargin="0">
足够容易,并且更少的代码和错误开销:)
在您的WebView上设置一个侦听器:
webView.setOnTouchListener(new View.OnTouchListener() {
public boolean onTouch(View v, MotionEvent event) {
return(event.getAction() == MotionEvent.ACTION_MOVE));
}
});
return
行末尾有一个额外的括号。这也会中断HTML5 canvas和JavaScript触摸事件。
event.getAction() != MotionEvent.ACTION_MOVE
以及return true
return false
,没有return true
。
我肮脏但易于实现且运行良好的解决方案:
只需将webview放入滚动视图中即可。使Web视图远远大于可能的内容(一维或二维,取决于要求)。..并根据需要设置滚动视图的滚动条。
禁用Web视图上的水平滚动条的示例:
<ScrollView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:scrollbars="vertical"
>
<WebView
android:id="@+id/mywebview"
android:layout_width="1000dip"
android:layout_height="fill_parent"
/>
</ScrollView>
我希望这有帮助 ;)
我通过以下方法解决了闪烁和自动滚动的问题:
webView.setFocusable(false);
webView.setFocusableInTouchMode(false);
但是,如果由于某种原因它仍然无法工作,只需创建一个扩展WebView的类,然后在其上放置此方法:
// disable scroll on touch
setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
return (event.getAction() == MotionEvent.ACTION_MOVE);
}
});
我建议扩展WebView,以提供更有效的控制,例如禁用/启用滑动,启用/禁用触摸,侦听器,控件转换,动画,内部定义设置等。
研究以上答案几乎对我有用...但是我仍然有一个问题,我可以“赞同” 2.1的观点(似乎已被2.2和2.3修正)。
这是我的最终解决方案
public class MyWebView extends WebView
{
private boolean bAllowScroll = true;
@SuppressWarnings("unused") // it is used, just java is dumb
private long downtime;
public MyWebView(Context context, AttributeSet attrs)
{
super(context, attrs);
}
public void setAllowScroll(int allowScroll)
{
bAllowScroll = allowScroll!=0;
if (!bAllowScroll)
super.scrollTo(0,0);
setHorizontalScrollBarEnabled(bAllowScroll);
setVerticalScrollBarEnabled(bAllowScroll);
}
@Override
public boolean onTouchEvent(MotionEvent ev)
{
switch (ev.getAction())
{
case MotionEvent.ACTION_DOWN:
if (!bAllowScroll)
downtime = ev.getEventTime();
break;
case MotionEvent.ACTION_CANCEL:
case MotionEvent.ACTION_UP:
if (!bAllowScroll)
{
try {
Field fmNumSamples = ev.getClass().getDeclaredField("mNumSamples");
fmNumSamples.setAccessible(true);
Field fmTimeSamples = ev.getClass().getDeclaredField("mTimeSamples");
fmTimeSamples.setAccessible(true);
long newTimeSamples[] = new long[fmNumSamples.getInt(ev)];
newTimeSamples[0] = ev.getEventTime()+250;
fmTimeSamples.set(ev,newTimeSamples);
} catch (Exception e) {
e.printStackTrace();
}
}
break;
}
return super.onTouchEvent(ev);
}
@Override
public void flingScroll(int vx, int vy)
{
if (bAllowScroll)
super.flingScroll(vx,vy);
}
@Override
protected void onScrollChanged(int l, int t, int oldl, int oldt)
{
if (bAllowScroll)
super.onScrollChanged(l, t, oldl, oldt);
else if (l!=0 || t!=0)
super.scrollTo(0,0);
}
@Override
public void scrollTo(int x, int y)
{
if (bAllowScroll)
super.scrollTo(x,y);
}
@Override
public void scrollBy(int x, int y)
{
if (bAllowScroll)
super.scrollBy(x,y);
}
}
这应该是完整的答案。如@GDanger所建议。扩展WebView以覆盖滚动方法,并将自定义Webview嵌入布局xml中。
public class ScrollDisabledWebView extends WebView {
private boolean scrollEnabled = false;
public ScrollDisabledWebView(Context context) {
super(context);
initView(context);
}
public ScrollDisabledWebView(Context context, AttributeSet attributeSet) {
super(context, attributeSet);
initView(context);
}
// this is important. Otherwise it throws Binary Inflate Exception.
private void initView(Context context) {
LayoutInflater inflater = (LayoutInflater) context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
}
@Override
protected boolean overScrollBy(int deltaX, int deltaY, int scrollX, int scrollY,
int scrollRangeX, int scrollRangeY, int maxOverScrollX,
int maxOverScrollY, boolean isTouchEvent) {
if (scrollEnabled) {
return super.overScrollBy(deltaX, deltaY, scrollX, scrollY,
scrollRangeX, scrollRangeY, maxOverScrollX, maxOverScrollY, isTouchEvent);
}
return false;
}
@Override
public void scrollTo(int x, int y) {
if (scrollEnabled) {
super.scrollTo(x, y);
}
}
@Override
public void computeScroll() {
if (scrollEnabled) {
super.computeScroll();
}
}
}
然后如下嵌入到布局文件中
<com.sample.apps.ScrollDisabledWebView
android:id="@+id/webView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_centerInParent="true"
tools:context="com.sample.apps.HomeActivity"/>
然后在“活动”中,也使用其他一些方法来禁用滚动条。
ScrollDisabledWebView webView = (ScrollDisabledWebView) findViewById(R.id.webView);
webView.setVerticalScrollBarEnabled(false);
webView.setHorizontalScrollBarEnabled(false);