任何人都可以在模拟手表示例android中解释这个表面逻辑

时间:2016-08-14 11:31:18

标签: android wear-os watchface

嗨我正在浏览模拟手表的样本。在onDraw方法中,我遇到了这个逻辑

find(topic:req.body.topic).sort({topic:1}).exec(function(err,result)
{
    var topic = result[0].topic + result[0].topic_text;//use index i to extract the value from result array.
})

我不明白这些行的确切含义

 @Override
    public void onDraw(Canvas canvas, Rect bounds) {
        mTime.setToNow();

        // Draw the background.
        if (isInAmbientMode()) {
            canvas.drawColor(Color.BLACK);
        } else {
            canvas.drawRect(0, 0, canvas.getWidth(), canvas.getHeight(), mBackgroundPaint);
        }

        // Find the center. Ignore the window insets so that, on round watches with a
        // "chin", the watch face is centered on the entire screen, not just the usable
        // portion.
        float centerX = bounds.width() / 2f;
        float centerY = bounds.height() / 2f;

        float secRot = (mTime.second / 30f) * (float) Math.PI;
        int minutes = mTime.minute;
        float minRot = minutes / 30f * (float) Math.PI;
        float hrRot = ((mTime.hour + (minutes / 60f)) / 6f) * (float) Math.PI;

        float secLength = centerX - 20;
        float minLength = centerX - 40;
        float hrLength = centerX - 80;

        if (!mAmbient) {
            float secX = (float) Math.sin(secRot) * secLength;
            float secY = (float) -Math.cos(secRot) * secLength;
            canvas.drawLine(centerX, centerY, centerX + secX, centerY + secY, mHandPaint);
        }

        float minX = (float) Math.sin(minRot) * minLength;
        float minY = (float) -Math.cos(minRot) * minLength;
        canvas.drawLine(centerX, centerY, centerX + minX, centerY + minY, mHandPaint);

        float hrX = (float) Math.sin(hrRot) * hrLength;
        float hrY = (float) -Math.cos(hrRot) * hrLength;
        canvas.drawLine(centerX, centerY, centerX + hrX, centerY + hrY, mHandPaint);
    }

1 个答案:

答案 0 :(得分:0)

似乎正在尝试计算每只手的旋转角度。它独立地移动秒针和分针,但移动时针也取决于分钟。在“12:30”,时针将在12到1之间。