`

scroll+zoom android textview

阅读更多

 

目标=把helloworld的文字变成可以缩放的,并可以移动文字块[scrollable]。

测试=需要能实体手机,虚拟机似乎不能进行触摸缩放测试。

版本=android 2.3.3,target=android-10

 

效果图

scroll text view

 

zoom text view

 

 

关键点

=============main.xml

 <TextView android:id="@+id/text"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:scrollbars = "vertical"
        android:text="@string/hello" />
显示纵向滚动条。

=============A1Activity.java
    tvPosSave.set(xt, yt);
记住文字块的位置。

关键文件代码
=============main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <TextView android:id="@+id/text"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:scrollbars = "vertical"
        android:text="@string/hello" />

</LinearLayout>
 
=============A1Activity.java
package com.ex.a1205;

import android.app.Activity;
import android.graphics.Point;
import android.graphics.PointF;
import android.os.Bundle;
import android.util.FloatMath;
import android.util.Log;
import android.util.TypedValue;
import android.view.Display;
import android.view.MotionEvent;
import android.view.View;
import android.view.WindowManager;
import android.view.View.OnTouchListener;
import android.widget.TextView;

public class A1Activity extends Activity implements OnTouchListener {
  enum Mode {
    NONE, DRAG, ZOOM
  }

  Mode mode = Mode.NONE;
  static final int MIN_FONT_SIZE = 20;
  static final int MAX_FONT_SIZE = 120;
  PointF start = new PointF();

  Point tvPos0 = new Point();
  Point tvPos1 = new Point();
  Point tvPosSave = new Point();

  float oldDist = 1f;
  int scrWidth;
  int scrHeight;
  TextView textView;

  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    textView = (TextView) findViewById(R.id.text);
    loadDoc();
    textView.setOnTouchListener(this);
    Display display = ((WindowManager) getSystemService(WINDOW_SERVICE))
        .getDefaultDisplay();
    scrWidth = display.getWidth();
    scrHeight = display.getHeight();
  }

  private void loadDoc() {
    StringBuilder sb = new StringBuilder();
    for (int i = 0; i <= 30; i++) {
      sb.append("Line: ").append(i).append("\n");
    }
    textView.setText(sb.toString());
  }

  public boolean onTouch(View v, MotionEvent event) {
    switch (event.getAction() & MotionEvent.ACTION_MASK) {
    case MotionEvent.ACTION_DOWN:
      start.set(event.getX(), event.getY());
      tvPos0.set((int) event.getX(), (int) event.getY());
      mode = Mode.DRAG;
      break;
    case MotionEvent.ACTION_POINTER_DOWN:
      oldDist = spacing(event);
      if (oldDist > 10f) {
        mode = Mode.ZOOM;
      }
      break;
    case MotionEvent.ACTION_UP:
    case MotionEvent.ACTION_POINTER_UP:
      mode = Mode.NONE;
      tvPos1.set(tvPosSave.x, tvPosSave.y);
      break;
    case MotionEvent.ACTION_MOVE:
      if (mode == Mode.DRAG) {
        doScroll(event);
      } else if (mode == Mode.ZOOM) {
        doZoom(event);
      }
      break;
    }
    return true;
  }

  private void doScroll(MotionEvent event) {
    int xe = (int) event.getX();
    int ye = (int) event.getY();
    int txtHeight = textView.getLineHeight() * (textView.getLineCount() - 2);
    int xt = tvPos1.x + tvPos0.x - xe;
    int yt = tvPos1.y + tvPos0.y - ye;
    if (xt < -textView.getRight()) {
      xt = -textView.getRight() + 20;
    } else if (xt > scrWidth) {
      xt = scrWidth - 20;
    }
    if (yt < -textView.getBottom()) {
      yt = -textView.getBottom() + textView.getLineHeight();
    } else if (yt > txtHeight) {
      yt = txtHeight;
    }
    textView.scrollTo(xt, yt);
    tvPosSave.set(xt, yt);
//    log("to(", xt, ",", yt, ")"
//        , " tHt=", txtHeight
//     );
  }

  void log(Object... objs) {
    StringBuilder sb = new StringBuilder();
    for (Object obj : objs) {
      sb.append(obj);
    }
    Log.d(A1Activity.class.getSimpleName(), sb.toString());
  }

  private void doZoom(MotionEvent event) {
    float newDist = spacing(event);
    if (newDist > 10f) {
      float scale = newDist / oldDist;
      if (scale > 1) {
        scale = 1.1f;
      } else if (scale < 1) {
        scale = 0.95f;
      }
      float currSize = textView.getTextSize() * scale;
      if ((currSize < MAX_FONT_SIZE && currSize > MIN_FONT_SIZE)
          || (currSize >= MAX_FONT_SIZE && scale < 1)
          || (currSize <= MIN_FONT_SIZE && scale > 1)) {
        textView.setTextSize(TypedValue.COMPLEX_UNIT_PX, currSize);
      }
    }
  }

  /** Determine the space between the first two fingers */
  private float spacing(MotionEvent event) {
    float x = event.getX(0) - event.getX(1);
    float y = event.getY(0) - event.getY(1);
    return FloatMath.sqrt(x * x + y * y);
  }

}
 
好树
好树

  • 大小: 4.2 KB
  • 大小: 19.4 KB
  • 大小: 46.9 KB
分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    android TextView android TextView

    ### Android TextView与ListView的Transcript Mode属性详解 在Android开发过程中,经常需要用到各种视图组件来展示信息。其中,`TextView`和`ListView`是非常重要的两个组件。它们不仅用于简单的文本展示,还可以...

    Android使用Scroll+Fragment仿京东分类效果

    Android 使用 Scroll + Fragment 仿京东分类效果 Android 中使用 Scroll + Fragment 仿京东分类效果是一种常用的设计模式,通过将 Scroll 和 Fragment 结合使用,实现了类似京东分类的效果。本文将详细介绍 ...

    infinitescroll+imagesLoaded+Masonry.zip

    这个压缩包 "infinitescroll+imagesLoaded+Masonry.zip" 提供了一个整合这三种技术的示例代码。 1. **Infinitescroll**:Infinitescroll 是一个 jQuery 插件,它允许网页内容随着用户滚动页面而动态加载。这种...

    Android文字竖直排版TextViewVertical(可横向滚动)(转)

    这个控件允许文字沿垂直方向排列,并且还支持横向滚动,这在原生的Android `TextView`中是默认不支持的。 `TextView`是Android SDK中内置的一个基本视图组件,通常用于显示单行或多行文本。然而,当文本内容过多时...

    android自定义横向跑马灯TextView(两种,即使一个字符也能跑马灯)

    "android自定义横向跑马灯TextView"就是一个典型的示例,它允许文字在一个视图内不断滚动,模拟LED显示屏上的跑马灯效果。这种效果通常用于显示通知、提示信息或者标题,即使只有一个字符也能实现滚动。 跑马灯效果...

    Scroll+pageControl

    在iOS开发中,实现“Scroll+pageControl”的功能通常涉及到UIScrollView和UIPageControl的自定义使用。这个功能的目的是创建一个界面,其中上半部分显示单张图片的滚动视图,下半部分则显示四张图片并能进行翻页。...

    Scroller简单例子-控制TextView左右移动

    在Android开发中,`Scroller`是一个非常重要的组件,它主要用于实现平滑的滚动效果,尤其是在没有用户交互的情况下。在给定的“Scroller简单例子-控制TextView左右移动”中,我们将探讨如何利用`Scroller`来实现一个...

    android之点击自动滚动textview

    在Android开发中,TextView是用于显示单行或多行文本的视图组件,它是我们日常开发中最常用的基础控件之一。然而,有时我们可能需要实现一个功能,即当用户点击TextView时,文本能自动滚动,这在展示长文本或公告时...

    Android自定义TextView实现跑马灯效果

    首先,我们需要创建一个新的Java类,继承自Android内置的TextView类。在自定义类中,我们需要重写onDraw()方法,因为这是绘制文本的核心部分。以下是一段基础的自定义TextView的代码框架: ```java public class ...

    android 自定义textview 模拟走马灯效果

    本文将深入探讨如何使用Android自定义TextView来模拟走马灯效果,即文字在视图中循环滚动,这种效果常见于新闻头条或者广告展示等场景。 首先,我们要明白走马灯效果的核心在于文本的动态滚动。在Android中,我们...

    TextView TextView Scroll

    TextView TextView ScrollTextView TextView ScrollTextView TextView ScrollTextView TextView ScrollTextView TextView ScrollTextView TextView...TextView ScrollTextView TextView ScrollTextView TextView Scroll

    绝版的POINTIX SCROLL PLUS 2.05

    鼠标增强工具,最好用的还是顺时针转动前进,逆时针转动后退,对于笔记本用户来说比较实用

    FastScrollBar:Android快速滚动条,配合listview使用

    " http://schemas.android.com/apk/res/android " xmlns : tools = " http://schemas.android.com/tools " xmlns : fast = " http://schemas.android.com/io.github.guaidaodl.fastscrollbar " android :...

    scroll view zoom

    我们将深入探讨`UIScrollView` 的基本概念、如何设置`UIImageView` 的拖拉和缩放功能,以及如何通过手势识别器来实现点击放大(Tap To Zoom)的功能。 首先,我们需要理解`UIScrollView` 的工作原理。`UIScrollView...

    处理Scroll View+ViewPager的高度,内存问题

    通过自定义控件来解决Scroll View+ViewPager的高度,内存问题

    Disable Ctrl + Scroll Wheel Zoom-crx插件

    语言:English 在Chrome中禁用Ctrl +滚轮缩放快捷键。 此扩展程序禁用了Chrome中的Ctrl +滚轮缩放快捷方式。 首次安装后,您可能需要重新加载标签页或重新启动Chrome。 请注意,它不适用于:-Chrome网上应用店中的...

    TextView Html.fromHtml ScrollView——可追加自动显示最后行

    在Android开发中,TextView是用于显示单行或多行文本的常用组件,但其默认功能相对较弱,不支持复杂的文本格式化。为了实现更丰富的文本展示,开发者常常会结合使用`Html.fromHtml`和ScrollView来创建一个可以显示富...

    XQScrollPage(横向Table包含纵向Table)

    实现横向滚动视图里含有可以纵向滑动的Table,也可以理解为横向table嵌套纵向table(与appstore布局相反)。横向的scrollView上面始终只有3个View,重复使用,避难内存紧张,适用于做类似卡片的应用。

    垂直滚动的textview

    在Android开发中,`TextView`是用于展示文本的常见组件,但默认情况下,它只能显示一行或多行静态的文本。然而,在某些场景下,我们可能需要实现文本的滚动效果,例如公告、滚动字幕等,这时就需要用到“垂直滚动的`...

Global site tag (gtag.js) - Google Analytics