- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试在 android 图库小部件中缩放/平移图像。图像覆盖整个屏幕。虽然我可以缩放/平移图库中的图像,但我无法滑动到下一张/上一张图像。单个图像的缩放和平移效果很好。
我从 Hello Android 书中创建了一个 TouchImageView,它扩展了具有缩放和平移功能的 ImageView。然后我在将图像返回到图库的适配器类的 getView() 方法中返回了这个 TouchImageView。
我在 http://groups.google.com/group/android-developers/msg/97421179bfc5a3b2 的谷歌群组中发现了完全相同的问题但那边没有回复。
谢谢。
最佳答案
我通过创建一个从 Gallery 小部件类派生的新类来解决这个问题。我叫我的 ZoomableGallery。我让我的实现了一些手势监听器来处理非多点触控或 pre 2.0 设备上的缩放和双击缩放。
public class ZoomableGallery extends Gallery implements OnDoubleTapListener, OnGestureListener, OnScaleGestureListener {}
关键是不要让您的内部小部件消耗触摸事件。创建响应触摸事件并放大和缩小的 ZoomablePannableImageView 似乎是正确的想法。这似乎是个好主意,因为这个可重用的组件在 Gallery 之外也能很好地工作。但是我认为它不能很好地工作。最好的方法是创建一个不处理触摸事件或设置任何 gesturelisteners 的 ZoomableImageView,而是提供一个 api,用于设置比例因子和平移 X、Y 维度作为常规方法。
然后,一旦您完成了这条路线,您就可以让 Gallery 小部件的后代巧妙地处理所有触摸事件,只转发需要转到小部件的触摸 Action fragment 。我的意思是,如果说我们放大了图像,我们几乎看到了整个图像,除了左边屏幕外有 4 个像素。如果我们收到一个触摸事件,将图像向右滚动 8 个像素。我们的图库小部件需要向图像小部件发送一个 pan 4 pixels right 消息。然后它本身也需要消耗 4 个像素的水平运动。因此, ImageView 不仅会显示其完整的左边缘,而且会向右滑动一点,可能会显示图库适配器中的下一个 ImageView 。
在扩展 Gallery 的新类中要覆盖的关键函数是:
@Override
public boolean onTouchEvent(MotionEvent event) {}
和
@Override
public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,
float distanceY) {}
我不想复制和粘贴我的整个实现,因为它杂乱无章且难以理解,而且在压力下它还会显示一些故障行为。但我不认为这是因为我采用的策略,而仅仅是因为我还没有清理它。
关键是要记住用户所处的模式(缩放,或在图像内部平移,平移整个画廊)
在用户在图像内部平移的情况下,我的代码看起来像在 onScroll 方法内处理 switch 语句:
case INNERDRAG:
float unhandledPan = mCurrentPannable.panHorizontally(distanceX);
// Negative unhandled pan means that we are shifting over to the image to the right
if (unhandledPan != 0.0f) {
if (unhandledPan < 0.0f)
mMode = GALPANRIGHT;
else
mMode = GALPANLEFT;
return super.onScroll(e1,e2,0.0f-unhandledPan,distanceY);
} else {
return true;
}
在此代码中,mCurrentPannable 指的是画廊当前“选择”的 View 。 Pannable 只是一个接口(interface),它将 panHorizontally 和 panVertically 定义为做两件事的函数:尝试将内部 View 平移这么多像素,如果该平移量超出它可以平移的边缘,它返回像素数它无法处理。
然后 gallery 不会将相同的参数传递给 super.onScroll,它只会传递 pan 未使用的内容。
希望对您有所帮助。
关于android - 画廊内的图像缩放/平移,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5011994/
我正在为我的网站编辑/创建以下脚本。正如你在下面看到的,我希望他添加一个 在每一行的开头。 (很难解释)。然后使用 var“getal”,我希望他在 4 个项目之后结束这个 DIV 标签(4x for
您好,我想使用 android 画廊和 gridview 教程开发相册,当我在 gridview 中单击图像时,单击图像位置的画廊 Activity 。 最佳答案 如果我是对的,您需要使用其位置转到图
我正在计划一个动态的 PHP 照片库,但在确定通过 MySQL 检索缩略图后显示缩略图的最佳方式时遇到了困难。我考虑过使用内联无序列表,但这导致拇指一个叠一个(触摸)。还尝试了一个表格,但不确定如何在
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
您好,我在使用 JS 创建动态图库时遇到了问题: 我不知道如何使用 JS - “gallery-pk-1-1”获取我的画廊 我不会用JS在相册中添加图片 点击打开漂亮的画廊(如果我只是使用上
有人会告诉我为什么:悬停不检测正确的 child 只将整体视为一个元素,即使我区分了更多的 child 并且一直在同一屏幕上更改我,如何解决?当我尝试将鼠标悬停在元素“.image”上时,我需要这样做
我正在尝试制作一个响应式 9×9 画廊,在悬停时带有叠加层(尝试使用带有颜色和文本的 div)。像这样:Slide in Overlay from the Bottom . 但是,我不能完全覆盖图像。
我想实现一个允许用户将项目拖出的画廊。这不应该妨碍滚动/滑动。 鉴于界面布局,用户只能沿垂直路径将项目拖出图库,并水平滚动图库。 这可行吗?有没有一种简单的方法来检测水平运动,将它们推迟到画廊的事件处
我正在尝试使用 Gallery 小部件构建一组水平滚动的 Web View 。问题是我无法滑动 View ,这当然适用于图像库。按照食谱代码,在 Activity 的 onCreate() I 中:
我正在尝试获取一个 slider 来展示我在帖子中的图片。我目前已设置好所有内容,但我只有一个 li 元素显示所有三张图片。我很想拥有三个 li 元素,每个元素显示一张图片,但我不知道如何自动隔离每张
我们使用的是 jQuery 1.7.1 和 Fancybox 1.3.4。我是 Fancybox 的新手。昨天之前我从未使用过它,但它在我正在工作的网站上广泛使用。设立 Fancybox 的人被解雇了
我想在我的 Activity 中查看画廊,但我不知道它发生了什么,它没有显示任何内容并崩溃。 在创建 Activity 方法时,我有: // initializing gallery view wit
我想根据数组中设置的图像数量创建一个图像 block 。喜欢这个画廊 block : [![在此处输入图像描述][1]][1] 我尝试的是这样的:
我有几个Venobox同一页面上的画廊。有些画廊有数百张照片,这就是为什么我只显示每个画廊的前 3 张缩略图。 当用户开始查看某个图库(单击任何缩略图)时,必须出现单击的图像,并且后台
我正在将 GLightbox JS 库用于作品集图库,并希望在单击内部元素外部时能够关闭图库。 我发现了类似性质的其他问题,但我避免使用 jQuery,并且无法找到适合此特定用例的解决方案。另外,看起
所以我试图循环遍历这个数组并每隔几秒更改一个图像源。现在我有一个 onload 事件调用 setTimeOut 方法,我认为该方法应该在页面加载后 5 秒更改图像,但它是立即执行的。问题是什么?这是我
我对 javascript 相当陌生,但我基本上试图通过图库进行下一次/上一次点击。我设法找到了教程和位来获取图像以供点击。但是我似乎无法弄清楚如何在第四张(最后一张)图像之后返回到该系列的开头。 这
我有一页 6 张图片,每张图片都不同的房子。单击时,我希望每张图像都能打开一个 fancybox 画廊,其中包含同一所房子的 4 张新的更详细的图像。最后,我希望 fancybox 中的 4 张详细照
我正在开发一个带有缩略图的简单 jQuery 图片库。 我想要的部分功能是,如果您单击当前显示的主画廊幻灯片 .show,它会删除 show 类,并淡出然后淡入下一张幻灯片并向其添加一个 show 类
我正在创建一个模板。除了 jquery 图像库之外,所有 xhtml/css 工作都已完成。周围有太多jquery库,我不知道如何根据情况定制它们 这是一个三列模板。第一列有导航。第二列将从第三列的缩
我是一名优秀的程序员,十分优秀!