首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用dp尺寸绘制

用dp尺寸绘制
EN

Stack Overflow用户
提问于 2014-07-24 15:06:52
回答 1查看 323关注 0票数 0

我有一个创建一个圆圈的循环,所有的工作,但是在不同的设备上我得到不同的油漆尺寸,我认为这是一个密度问题,我如何解决这个问题?

这是我的密码:

代码语言:javascript
复制
for(int i=0; i<360; i = i + 12){
    x = (float) (view.getWidth()/2 + raggio_in * Math.cos(Math.toRadians(i)));
    y = (float) (view.getHeight()/2 + raggio_in * Math.sin(Math.toRadians(i)));                 
    Paint paint = new Paint();
    paint.setFlags(Paint.ANTI_ALIAS_FLAG);
    paint.setColor(getResources().getColor(R.color.tutorial_text));     
    if(i < progress){
        paint.setColor(Color.WHITE);
        }
    canvas.save(Canvas.MATRIX_SAVE_FLAG);
    canvas.rotate(i, x, y);
    canvas.drawRoundRect(new RectF((float) x-deltaX, (float) y-deltaY, (float) x+deltaX, (float) y+deltaY), raggio_elemento, raggio_elemento, paint);
    canvas.restore();
    x = (float) (view.getWidth()/2 + raggio_out * Math.cos(Math.toRadians(i)));
    y = (float) (view.getHeight()/2 + raggio_out * Math.sin(Math.toRadians(i)));
    paint = new Paint();
    paint.setColor(getResources().getColor(R.color.tutorial_text));
    if(i < progress){
        paint.setColor(Color.WHITE);
    }
    canvas.save(Canvas.MATRIX_SAVE_FLAG);
    canvas.rotate(i, x, y);
    canvas.drawRoundRect(new RectF((float) x-deltaX, (float) y-deltaY, (float) x+deltaX, (float) y+deltaY), raggio_elemento, raggio_elemento, paint);
    canvas.restore();   
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-07-24 15:09:50

您可以这样计算dp中的维数:

代码语言:javascript
复制
pixels * density + 0.5f

density可以是访问调用context.getResources().getDisplayMetrics().density

0.5f用于舍入。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24937450

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档