- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图让我的应用程序显示一个圆圈,用户可以通过触摸并拖动该圆圈来将其旋转到一定程度。假设圆最大可以旋转 60 度,无论哪种方式。
我已经扩展了 View 类来创建我的自定义 View 。我用 drawCircle() 方法在我的 Canvas 上画了一个圆。要旋转它,我知道我必须执行 canvas.rotate(),但我不确定将中心固定为什么。我如何测量这个角度?我旋转什么?
public class DrawingView extends View {
Paint paint;
Canvas canvas;
int originalX = 100;
int originalY = 50;
int radius = 75;
// ... some code ...
// paint, canvas initialised in constructors
@Override
protected void onDraw(Canvas canvas){
canvas.drawCircle(originalX, originalY, radius, paint);
// some more code ...
}
@Override
public boolean onTouchEvent(MotionEvent event){
int x = (int)event.getX();
int y = (int)event.getY();
case MotionEvent.ACTION_DOWN:
// Detect if touch in my circle
break;
case MotionEvent.ACTION_MOVE:
double tx = x - originalX;
double ty = y - originalY;
double tlength = Math.sqrt(tx*tx + ty*ty);
double angle = Math.acos(radius/tlength);
double degrees = (angle * 180)/Math.PI;
System.out.println("Degrees " + (angle*180)/Math.PI);
break;
}
}
我显示的代码似乎没有给我正确的值。就像,如果我一直触摸并拖动到屏幕的末端,它会给我一个大约 70 度的值。我认为我没有正确计算角度,但我也不知道如何计算。
我按照所选答案的方式寻找角度。然后我在画圆之前使用了 canvas.rotate()。
最佳答案
我不确定我是否了解您对这应该如何运作的想法。但是那里的几何形状肯定很奇怪。 tlength
是从圆心到指压的半径,您正在对它进行 acos。但是,那是错误的。 acos 是哪些值可以为您提供该值的 cos。从理论上讲,这将是不同角度的余弦波。这可能很有趣,但听起来不像你想要的。听起来您想将距离 0 的中心称为旋转 -60 度,将半径旋转 0 度,将 2*radius 旋转 +60 度。所以就这样做吧。您线性插值距离 (60° * (distance/radius)) - 60° 或其他。
虽然从 UI 的角度来看,您最好让用户通过将手指移动到该角度来更改圆上的实际角度。然后将这些值放入 atan2() 并在超出允许范围时对其进行限制。
有很多方法可以做到这一点。您可以根据手指按压来计算角度。因此,您可以使用中心点和当前极坐标等已知点。所以如果你有一个距离为 r 的当前角度,那么另一端的点是 cos(x)*r
,如果你有 x 和 sin(y)*r
你想要的那个终点的 y 那么到中心的距离是 sqrt(dx*dx + dy*dy)
它所在的角度是 atan2(dy, dx)
。所以你可以通过一点三角从极坐标转到笛卡尔坐标。如果您想将圆心和半径之间的差称为角度,您可以对其进行线性插值。
这是一个 View 的快速呈现,它是这样做的。还有其他 UI 选项可以替代,例如不执行实际角度而是更改角度,这样您就可以像移动旋钮或其他东西一样移动圆圈。
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
public class RotateCircleView extends View {
static final double TAU = Math.PI * 2;
Paint paint;
double angle = 0;
double radius = 0;
double ix = Double.NaN, iy = Double.NaN;
public RotateCircleView(Context context) {
super(context);
init();
}
public RotateCircleView(Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
init();
}
public RotateCircleView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init();
}
public void init() {
paint = new Paint();
paint.setAlpha(100);
paint.setStrokeWidth(20);
}
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
super.onSizeChanged(w, h, oldw, oldh);
ix = w / 2.0;
iy = h / 2.0;
radius = Math.min(ix, iy) / 2.0;
invalidate();
}
@Override
protected void onDraw(Canvas canvas) {
if (Double.isNaN(ix)) return;
super.onDraw(canvas);
canvas.save();
canvas.rotate((float) ((TAU * -angle) / 360.0), (float) ix, (float) iy);
canvas.drawCircle((float) ix, (float) iy, (float) radius, paint);
double limit = TAU / 6.0;
if (angle > limit) angle = limit;
if (angle < -limit) angle = -limit;
double tx = ix + Math.cos(angle) * radius;
double ty = iy + Math.sin(angle) * radius;
canvas.drawLine((float) ix, (float) iy, (float) tx, (float) ty, paint);
canvas.restore();
}
public boolean onTouchEvent(MotionEvent event) {
double mx = event.getX();
double my = event.getY();
double dx = mx - ix;
double dy = my - iy;
switch (event.getAction()) {
case MotionEvent.ACTION_MOVE:
//radius = Math.sqrt(dx * dx + dy * dy);
angle = Math.atan2(dy, dx);
invalidate();
break;
}
return true;
}
}
关于java - 将 Canvas 上绘制的圆圈旋转到触摸标记的点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55387714/
我该怎么做 touch R 中的文件(即更新其修改时间而不更改其内容)?我正在寻找一个跨平台的内置(或打包)等效于: system2("touch", file_name) 最佳答案 我找到了 an
我想在 android 中实现 body 部位选择。我的要求是,当我点击特定部分时,图像应用程序应该能够识别 body 部位并且所选部分的颜色应该改变。附上示例图像以供引用。 如有任何想法或建议,我们
我需要将3D模型加载到我的应用程序中(不是游戏,它没有任何区别),并检测用户何时触摸此模型的特定部分以采取不同的操作。 我怎样才能做到这一点?可能吗? 最佳答案 我不熟悉Rajawali,但GitHu
似乎连续触摸总是被它起源的控件捕获。是否有标准方法将触摸/手势传递给当前触摸结束的控件? 最佳答案 控件显示在 UIView 对象内部的屏幕上。 iOS 使用第一响应者的概念来处理 UIView 对象
我有一个 UIScrollView 实例,允许用户放大/缩小。我已经根据文档实现了一个委托(delegate)来处理这个问题。但是,我想知道用户触摸 ScrollView 的位置(相对于 Scroll
我正在创建一款射击游戏,您可以触摸屏幕,玩家可以射击。我遇到的问题是,当你触摸屏幕并按住它并拖动它时,它会快速射击。处理这个问题的最佳方法是什么? 我希望玩家能够按住手指并以稳定的速度射击,而手指向上
- (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typ
这是我从触摸事件中获得的返回数据。明显缺少任何有用的触摸 X/Y 坐标 ( https://developer.mozilla.org/en-US/docs/Web/API/TouchEvent/ch
因此,我有一个屏幕,其中包含 0 到 6 个通过 XML 包含的相同用户界面组件。类似这样的东西: ...等等 每个包含的 UI 都是我重复使用的几个小部件和自定义组件的集
我希望能够更改文件的修改日期以便在 Web 应用程序中使用。目前我直接在命令行上测试这个。在我的 Mac 上工作正常,但是当我在 Linux 服务器上执行此操作时出现错误。 命令:/bin/touch
概念问题: 我在使用 touches 时遇到了一个非常简单的问题属性,自动更新依赖模型的时间戳;它正确地这样做了,但也应用了全局范围。 有什么办法可以关闭这个功能吗?或专门询问自动 touches忽略
我很难在一个简单的等距 Sprite Kit 游戏中实现点击处理。 我有一个包含多个 Tile 对象(SKSpriteNode)的 map (SKNode)的游戏场景(SKScene)。 这是 map
有没有办法在触摸事件后恢复 Flexslider 幻灯片的自动播放?现在看来,一旦我滑动导航,幻灯片就会停止...... 最佳答案 FLEXISLIDER 2 更新 resume()事件不再存在,正确
有些游戏有一些小图片作为 Sprite ,可以通过触摸来移动。如果 Sprite 是较大的图片,触摸是很正常的。我们可以使用函数CGRectContainsPoint检查 Sprite 。但是当 Sp
我有一个 View 覆盖到 iPhone 的相机 View 上。在此 View 中,我有一些 uibuttons,它们显示的位置取决于加速度计/指南针的值。当用户在 View 内触摸但没有在 uibu
我有一个 UIView 和一个 UIWebView。 UIWebView 是 UIView 的 subview 。 UIWebView 包含 YouTube 视频,并设置为让视频适合 UIWebVie
我是通过 XCode 使用 SDK 版本 5.0 进行 iOS 开发的新手。在我的应用程序中,我需要在按下按钮时更改按钮的标题。 假设在正常状态下它是“未推送”的。我所需要的是,当我按下按钮时,按钮标
我需要防止我的网络应用程序中的水平滚动。我尝试在 touchmove 事件上使用 PreventDefault(),但它也阻止垂直滚动。 有什么想法吗?^^ 我的尝试: $(document)
对于完全适合动画组方法的动画效果,如Brad Larson's answer here所示,我需要动画根据输入进行。特别是触摸和检测到的触摸的位置。处理 TouchMoved: 并为每次触摸设置元素的
我在屏幕上散布了一系列硬币。我想在触摸硬币时添加声音。 private Music coinSound; 在 show() 中: coinSound=assetManager.get(Assets.c
我是一名优秀的程序员,十分优秀!