我正在寻找一种在android(Imageview,Button或frame)中制作某种类型的倾斜视图的方法
我可以实现的任何东西点击它.
这样的Windows手机有一些风格:

或类似的东西:

屏幕的每个部分(黑线上方或下方)都是可点击的,并且可以进行新的活动.使用staggeredgridview显示具有不同列大小的网格没有问题.但我想这种方法我应该制作服装布局框架而不是网格?
我在play.google.com上找到了另一个示例:

它可以在某个地方制作一些封面和图像,但每个视图都没有onclick功能.
编辑:从Ernir部署建议:
public abstract class MainActivity extends Activity implements View.OnTouchListener {
final ImageView iv= (ImageView)findViewById(R.id.img_cut_1);
final ImageView iv2= (ImageView)findViewById(R.id.img_cut_2);
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
findViewById(R.id.img_cut_1).setOnTouchListener(new MyTouchListener());
}
private final class MyTouchListener implements OnTouchListener {
@Override
public boolean onTouch(View v, MotionEvent me) {
if (me.getAction() == MotionEvent.ACTION_DOWN) {
int vid = v.getId();
int nTouchX = (int)me.getX();
int nTouchY = (int)me.getY();
if (vid == R.id.img_cut_1) {
Bitmap bm = ((BitmapDrawable)iv.getDrawable()).getBitmap();
if (bm.getPixel(nTouchX, nTouchY) != 0) {
Log.i("MyActivity", "img_cut_1 true");
return true;
}
return false;
}
if (vid == R.id.img_cut_2) {
Bitmap bm = ((BitmapDrawable)iv2.getDrawable()).getBitmap();
if (bm.getPixel(nTouchX, nTouchY) != 0) {
Log.i("MyActivity", "img_cut_2 true");
return true;
}
return false;
}
}
return true;
}
}
Run Code Online (Sandbox Code Playgroud)
和布局:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >
<FrameLayout
android:id="@+id/frame"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<ImageView
android:id="@+id/img_cut_1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:scaleType="center"
android:src="@drawable/image_cut_1" />
<ImageView
android:id="@+id/img_cut_2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:scaleType="center"
android:src="@drawable/ic_launcher" />
</FrameLayout>
</RelativeLayout>
Run Code Online (Sandbox Code Playgroud)
但得到这个错误:
01-06 11:06:33.242: E/AndroidRuntime(15737): FATAL EXCEPTION: main
01-06 11:06:33.242: E/AndroidRuntime(15737): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.test.com/com.example.test.com.MainActivity}: java.lang.InstantiationException: com.example.test.com.MainActivity
01-06 11:06:33.242: E/AndroidRuntime(15737): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1573)
01-06 11:06:33.242: E/AndroidRuntime(15737): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)
01-06 11:06:33.242: E/AndroidRuntime(15737): at android.app.ActivityThread.access$1500(ActivityThread.java:117)
01-06 11:06:33.242: E/AndroidRuntime(15737): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
01-06 11:06:33.242: E/AndroidRuntime(15737): at android.os.Handler.dispatchMessage(Handler.java:99)
01-06 11:06:33.242: E/AndroidRuntime(15737): at android.os.Looper.loop(Looper.java:130)
01-06 11:06:33.242: E/AndroidRuntime(15737): at android.app.ActivityThread.main(ActivityThread.java:3687)
01-06 11:06:33.242: E/AndroidRuntime(15737): at java.lang.reflect.Method.invokeNative(Native Method)
01-06 11:06:33.242: E/AndroidRuntime(15737): at java.lang.reflect.Method.invoke(Method.java:507)
01-06 11:06:33.242: E/AndroidRuntime(15737): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
01-06 11:06:33.242: E/AndroidRuntime(15737): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
01-06 11:06:33.242: E/AndroidRuntime(15737): at dalvik.system.NativeStart.main(Native Method)
01-06 11:06:33.242: E/AndroidRuntime(15737): Caused by: java.lang.InstantiationException: com.example.test.com.MainActivity
01-06 11:06:33.242: E/AndroidRuntime(15737): at java.lang.Class.newInstanceImpl(Native Method)
01-06 11:06:33.242: E/AndroidRuntime(15737): at java.lang.Class.newInstance(Class.java:1409)
01-06 11:06:33.242: E/AndroidRuntime(15737): at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
01-06 11:06:33.242: E/AndroidRuntime(15737): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1565)
01-06 11:06:33.242: E/AndroidRuntime(15737): ... 11 more
Run Code Online (Sandbox Code Playgroud)
香港专业教育学院试图将整个方法添加到另一个活动,但没有帮助.我在类中添加方法,因为你提到的单词"相同的OnTouchListener到所有的ImageViews".
最好的解决方案是将标准化图像划分为多边形,其中每个多边形代表一个可点击区域。然后附加一个 OnTouchListener 并检查标准化触摸坐标是否在多边形内。该解决方案需要程序员做一些工作以及几何算法的实现。我不会进一步讨论该解决方案,而是向您提供最简单的解决方案,该解决方案需要您花费最少的时间来实施。我猜这就是你想要的,我希望我是对的:)。
请注意,此解决方案内存效率不高,应谨慎使用
1.将图像切割成多个相同大小的图像,每个图像仅包含一个可点击区域,其余部分是透明的。如果我使用您问题中的第一张图片作为示例,那么其中一张图片将如下所示:

(来源:magma.is)
2.现在将这些图像叠加在多个重叠的 ImageView 中
....
<FrameLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<ImageView
android:id="@+id/img_cut_1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:scaleType="center"
android:src="@drawable/image_cut_1" />
<ImageView
android:id="@+id/img_cut_2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:scaleType="center"
android:src="@drawable/image_cut_2" />
...
Run Code Online (Sandbox Code Playgroud)
3.在您的 Activity/Fragment 中,为所有 ImageView设置相同的OnTouchListener。在那里,您可以通过透明度消除来发现哪个 ImageView 被真正触摸,然后您就可以获得有关图像的哪个区域(或按钮,如果您愿意)被按下的信息。
@Override
public boolean onTouch(View v, MotionEvent me) {
if (me.getAction() == MotionEvent.ACTION_DOWN) {
int nTouchX = (int)me.getX();
int nTouchY = (int)me.getY();
if (v == imageCut1) {
Bitmap bm = ((BitmapDrawable)imageCut1.getDrawable()).getBitmap();
if (bm.getPixel(nTouchX, nTouchY) != 0) {
// non-transparent pixel touched, we found our view, receive further motion events. This can also be set false and code inserted here.
return true;
}
// transparent pixel touched, do not receive further motion events.
return false;
}
if (v == imageCut2) {
...
Run Code Online (Sandbox Code Playgroud)
如果您只需要用户点击,则可以继续并行使用 OnClick 或更好,使用 MotionEvent.ACTION_UP 操作并检查点击漂移以及 DOWN 和 UP 运动事件之间的最大时间延迟。MotionEvent.ACTION_UP 中的类似内容:(请注意,只有“正确”的 ImageView 才会为您提供此运动事件,因为我们放弃了其他视图的进一步运动事件)
if (
mMainDragStartX <(me.getX()+TAP_DRIFT_TOLERANCE) &&
mMainDragStartX > (me.getX() -TAP_DRIFT_TOLERANCE) &&
mMainDragStartY < (me.getY() + TAP_DRIFT_TOLERANCE) &&
mMainDragStartY > (me.getY() - TAP_DRIFT_TOLERANCE) &&
((SystemClock.elapsedRealtime() - mMainDraggingStarted) < SINGLE_TAP_MAX_TIME)) {
// The user has tapped!
...
Run Code Online (Sandbox Code Playgroud)