`

android webview 文字复制

阅读更多

将下面的类作为一个工具类,放到项目中,

package local.nt.phone.activity;

import java.lang.reflect.Method;

import android.app.Activity;
import android.os.Build;
import android.util.Log;
import android.view.ContextMenu;
import android.view.ContextMenu.ContextMenuInfo;
import android.view.KeyEvent;
import android.view.Menu;
import android.view.MenuItem;
import android.view.MenuItem.OnMenuItemClickListener;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.view.ViewConfiguration;
import android.webkit.WebView;

public class WebViewCopy {
private Activity activity;
private WebView webview;
private static boolean mIsSelectingText;

public static final String TAG=WebViewCopy.class.getSimpleName();
public WebViewCopy(final Activity activity, final WebView webView){
this.webview=webView;
this.activity=activity;
this.activity.registerForContextMenu(this.webview);
webView.requestFocus(View.FOCUS_DOWN);
webView.setOnTouchListener(new OnTouchListener() {

boolean mHasPerformedLongPress;
Runnable mPendingCheckForLongPress;


@Override
public boolean onTouch(final View v, MotionEvent event) {

/* webView.getSettings().setBuiltInZoomControls(false);
webView.getSettings().setSupportZoom(false);*/
Log.d(TAG, "event:" + event.getAction());

switch (event.getAction()) {
case MotionEvent.ACTION_UP:
mIsSelectingText = false;
if (!v.hasFocus()) {
v.requestFocus();
}

if (!mHasPerformedLongPress) {
// This is a tap, so remove the longpress check
if (mPendingCheckForLongPress != null) {
v.removeCallbacks(mPendingCheckForLongPress);
}
// v.performClick();
}

break;
case MotionEvent.ACTION_DOWN:

if (!v.hasFocus()) {
v.requestFocus();
}

if( mPendingCheckForLongPress == null) {


mPendingCheckForLongPress = new Runnable() {
public void run() {
//((WebView)v).performLongClick();
if(! mIsSelectingText) {
activity.openContextMenu(webview);
mHasPerformedLongPress = true;
mIsSelectingText = false;
}
}
};

}


mHasPerformedLongPress = false;
v. postDelayed(mPendingCheckForLongPress, ViewConfiguration.getLongPressTimeout());

break;

case MotionEvent.ACTION_MOVE:
final int x = (int) event.getX();
final int y = (int) event.getY();

// Be lenient about moving outside of buttons
int slop = ViewConfiguration.get(v.getContext()).getScaledTouchSlop();
if ((x < 0 - slop) || (x >= v.getWidth() + slop) ||
(y < 0 - slop) || (y >= v.getHeight() + slop)) {

if (mPendingCheckForLongPress != null) {
v. removeCallbacks(mPendingCheckForLongPress);
}

}
break;
default:
return false;

}

return false;

}
});





}

public static synchronized void emulateShiftHeld(WebView view)
{

try
{
KeyEvent shiftPressEvent = new KeyEvent(0, 0, KeyEvent.ACTION_DOWN,
KeyEvent.KEYCODE_SHIFT_LEFT, 0, 0);
shiftPressEvent.dispatch(view);
}
catch (Exception e)
{
Log.e(TAG, "Exception in emulateShiftHeld()", e);
}
}

public synchronized void onCreateContextMenu(ContextMenu menu, View v,
ContextMenuInfo menuInfo,final int copy,String menuString) {
MenuItem menuitem=menu.add(1, copy, Menu.NONE, menuString);
menuitem.setOnMenuItemClickListener(new OnMenuItemClickListener() {

@Override
public boolean onMenuItemClick(MenuItem item) {
if(item.getItemId()==copy){
//emulateShiftHeld(webview);
selectAndCopyText(webview);
}
return false;
}
});
}
public static synchronized void selectAndCopyText(WebView v) {
try {

mIsSelectingText = true;

//Method m = WebView.class.getMethod("emulateShiftHeld", Boolean.TYPE);
// m.invoke(v, false);

if (android.os.Build.VERSION.SDK_INT <= Build.VERSION_CODES.ECLAIR) {
Method m = WebView.class.getMethod("emulateShiftHeld", Boolean.TYPE);
m.invoke(v, false);
}
else {
Method m = WebView.class.getMethod("emulateShiftHeld");
m.invoke(v);
}

} catch (Exception e) {
// fallback
emulateShiftHeld(v);
}finally{
//Toast.makeText(activity, "Select text", Toast.LENGTH_SHORT).show();
}

}
}

 

 

之后在要用到的activity中,:myWebView = (WebView) findViewById(R.id.mainwebview);实例化webview,
copy = new WebViewCopy(this, myWebView);实例化工具类

再之后,重写onCreateContextMenu,如下

@Override
public void onCreateContextMenu(ContextMenu menu, View v,
ContextMenuInfo menuInfo) {
// TODO Auto-generated method stub

copy.onCreateContextMenu(menu, v, menuInfo,0,"复制");
super.onCreateContextMenu(menu, v, menuInfo);

}

这样在项目的相应的webview中就可以长按,出现复制文字的功能了

 

 

分享到:
评论

相关推荐

    Android WebView另类实现 自由复制进入选择文字模式

    本篇文章将深入探讨如何在Android WebView中实现自由复制和选择文字的功能,这对于增强用户体验至关重要,特别是对于那些包含大量文本内容的应用来说。 通常情况下,WebView默认并不支持用户直接复制文本,因此我们...

    Android webview 播放视频、文字复制

    二、Android WebView 文字复制 1. 允许选择文本:默认情况下,WebView可能不允许用户选择文本。我们需要开启文本选择功能: ```java webView.getSettings().setAllowUniversalAccessFromFileURLs(true); webView....

    安卓Android源码——BTAndroidWebViewSelection(webview选择文字).7z

    本项目可能包含了对WebView文字选择功能的优化或自定义实现。 1. **WebView的基本概念** WebView是Android SDK中的一个视图组件,它可以加载HTML、CSS、JavaScript等网页内容。它提供了一个桥梁,使得Android应用...

    安卓Android源码——BTWebViewSelection(webview选择文字).zip

    `BTWebViewSelection`项目提供了一种自定义Webview文字选择的方法,使开发者能够定制选中文本的样式、行为以及交互方式。以下是关于这个主题的一些关键知识点: 1. **WebView的Text Selection**:在Android中,...

    BTAndroidWebViewSelection.rar_WebView_android_android webview

    本文将深入探讨Android WebView控件以及如何实现文字选中功能,这对于提升用户体验至关重要。 首先,我们来了解Android WebView的基本用法。WebView是Android SDK中的一个类,位于`android.webkit`包下。通过实例化...

    BTAndroidWebViewSelection(webview选择文字).rar

    在Android开发中,Webview是一个非常重要的组件,它允许开发者在原生应用中嵌入网页内容,实现网页与原生应用的交互。本项目“BTAndroidWebViewSelection(webview选择文字)”专注于解决一个特定的问题:在Webview...

    WebView 自定义长按选择,实现收藏 / 分享选中文本

    在Android开发中,WebView是一个非常重要的组件,它允许我们在原生应用中展示网页内容。而WebView的自定义功能则是开发者常常需要处理的问题之一。本文将深入探讨如何在WebView中实现自定义长按选择,以及选中文本的...

    Android BTAndroidWebViewSelection(webview选择文字).zip

    在“Android BTAndroidWebViewSelection”项目中,开发者可能实现了自定义的文字选择颜色、样式或者添加了额外的选中文本操作,如复制、分享等。 3. **自定义选择器** 为了改变Webview的默认文字选择行为,开发者...

    2021-学习相关-BTAndroidWebViewSelection(webview选择文字).zip

    【BTAndroidWebViewSelection】是一个关于Android WebView选择文字功能的学习项目,源自2021年的学习资源。这个项目主要探讨了如何在Android应用中实现WebView组件的文本选择、复制和分享功能,这对于开发者来说是一...

    BTAndroidWebViewSelection(webview选择文字)

    `BTAndroidWebViewSelection` 是一个专门针对WebView文字选择功能的开源项目,提供了对WebView内文本的高亮、复制、分享等操作的支持。这个项目对于那些希望增强其应用程序内WebView交互性的开发者来说,具有很高的...

    BTAndroidWebViewSelection(webview选择文字)安卓源码.7z

    总的来说,BTAndroidWebViewSelection是一个对Android WebView文字选择功能进行增强的优秀开源项目,对于那些希望提供更丰富文本交互体验的开发者来说,这是一个非常有价值的工具。通过使用这个库,开发者可以提升...

    BTWebViewSelection(webview选择文字).zip

    `BTWebViewSelection(webview选择文字)`是一个针对Android Webview的特定功能模块,主要涉及用户在Webview中选择、复制、处理文本的功能。下面将详细探讨这一主题。 1. Android Webview基础: Android Webview是...

    安卓Android源码——BTAndroidWebViewSelection(webview选择文字).zip

    4. **WebView文字选择** - 默认情况下,WebView不支持文本选择。为了实现此功能,我们需要自定义`WebView`的触摸事件处理。 - `WebView.setOnTouchListener()`可以监听用户的触摸事件,当检测到长按事件时,启动...

    Android源码——BTAndroidWebViewSelection(webview选择文字).zip

    这个压缩包“Android源码——BTAndroidWebViewSelection(webview选择文字).zip”显然包含了针对WebView中文字选择功能的实现代码。下面我们将深入探讨Android WebView的选择文字功能及其相关知识点。 一、WebView...

    安卓Android源码——BTAndroidWebViewSelection(webview选择文字).rar

    【Android WebView选择文字详解】 在Android开发中,WebView是一个非常重要的组件,它允许开发者在应用程序中内嵌网页内容。这个项目“BTAndroidWebViewSelection”专注于WebView中的文本选择功能,这在许多应用...

    Android应用源码之BTAndroidWebViewSelection(webview选择文字).zip

    总之,BTAndroidWebViewSelection项目提供了在Android WebView中实现文字选择的示例,对于开发者来说,这是一个学习如何增强WebView功能的好资源。通过深入研究这个源码,你可以了解到如何定制WebView的行为,提高...

    Android-FlexibleRichTextView可以显示LaTeX图片代码的TextView

    这种方式不仅保持了公式清晰易读的排版,还避免了文字渲染的局限性。例如,你可以轻松地插入一个复杂的数学公式,如$e^{i\pi} + 1 = 0$,在用户界面上,它会被正确地渲染为对应的数学图像。 对于图片的显示,`...

Global site tag (gtag.js) - Google Analytics