目标=把helloworld的文字变成可以缩放的,并可以移动文字块[scrollable]。
测试=需要能实体手机,虚拟机似乎不能进行触摸缩放测试。
版本=android 2.3.3,target=android-10
效果图
关键点
=============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与ListView的Transcript Mode属性详解 在Android开发过程中,经常需要用到各种视图组件来展示信息。其中,`TextView`和`ListView`是非常重要的两个组件。它们不仅用于简单的文本展示,还可以...
Android 使用 Scroll + Fragment 仿京东分类效果 Android 中使用 Scroll + Fragment 仿京东分类效果是一种常用的设计模式,通过将 Scroll 和 Fragment 结合使用,实现了类似京东分类的效果。本文将详细介绍 ...
这个压缩包 "infinitescroll+imagesLoaded+Masonry.zip" 提供了一个整合这三种技术的示例代码。 1. **Infinitescroll**:Infinitescroll 是一个 jQuery 插件,它允许网页内容随着用户滚动页面而动态加载。这种...
这个控件允许文字沿垂直方向排列,并且还支持横向滚动,这在原生的Android `TextView`中是默认不支持的。 `TextView`是Android SDK中内置的一个基本视图组件,通常用于显示单行或多行文本。然而,当文本内容过多时...
"android自定义横向跑马灯TextView"就是一个典型的示例,它允许文字在一个视图内不断滚动,模拟LED显示屏上的跑马灯效果。这种效果通常用于显示通知、提示信息或者标题,即使只有一个字符也能实现滚动。 跑马灯效果...
在iOS开发中,实现“Scroll+pageControl”的功能通常涉及到UIScrollView和UIPageControl的自定义使用。这个功能的目的是创建一个界面,其中上半部分显示单张图片的滚动视图,下半部分则显示四张图片并能进行翻页。...
在Android开发中,`Scroller`是一个非常重要的组件,它主要用于实现平滑的滚动效果,尤其是在没有用户交互的情况下。在给定的“Scroller简单例子-控制TextView左右移动”中,我们将探讨如何利用`Scroller`来实现一个...
在Android开发中,TextView是用于显示单行或多行文本的视图组件,它是我们日常开发中最常用的基础控件之一。然而,有时我们可能需要实现一个功能,即当用户点击TextView时,文本能自动滚动,这在展示长文本或公告时...
首先,我们需要创建一个新的Java类,继承自Android内置的TextView类。在自定义类中,我们需要重写onDraw()方法,因为这是绘制文本的核心部分。以下是一段基础的自定义TextView的代码框架: ```java public class ...
本文将深入探讨如何使用Android自定义TextView来模拟走马灯效果,即文字在视图中循环滚动,这种效果常见于新闻头条或者广告展示等场景。 首先,我们要明白走马灯效果的核心在于文本的动态滚动。在Android中,我们...
TextView TextView ScrollTextView TextView ScrollTextView TextView ScrollTextView TextView ScrollTextView TextView ScrollTextView TextView...TextView ScrollTextView TextView ScrollTextView TextView Scroll
鼠标增强工具,最好用的还是顺时针转动前进,逆时针转动后退,对于笔记本用户来说比较实用
" 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 :...
我们将深入探讨`UIScrollView` 的基本概念、如何设置`UIImageView` 的拖拉和缩放功能,以及如何通过手势识别器来实现点击放大(Tap To Zoom)的功能。 首先,我们需要理解`UIScrollView` 的工作原理。`UIScrollView...
通过自定义控件来解决Scroll View+ViewPager的高度,内存问题
语言:English 在Chrome中禁用Ctrl +滚轮缩放快捷键。 此扩展程序禁用了Chrome中的Ctrl +滚轮缩放快捷方式。 首次安装后,您可能需要重新加载标签页或重新启动Chrome。 请注意,它不适用于:-Chrome网上应用店中的...
在Android开发中,TextView是用于显示单行或多行文本的常用组件,但其默认功能相对较弱,不支持复杂的文本格式化。为了实现更丰富的文本展示,开发者常常会结合使用`Html.fromHtml`和ScrollView来创建一个可以显示富...
实现横向滚动视图里含有可以纵向滑动的Table,也可以理解为横向table嵌套纵向table(与appstore布局相反)。横向的scrollView上面始终只有3个View,重复使用,避难内存紧张,适用于做类似卡片的应用。
在Android开发中,`TextView`是用于展示文本的常见组件,但默认情况下,它只能显示一行或多行静态的文本。然而,在某些场景下,我们可能需要实现文本的滚动效果,例如公告、滚动字幕等,这时就需要用到“垂直滚动的`...