资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

如何使用android画函数曲线

这篇文章主要介绍如何使用android画函数曲线,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

10余年的睢县网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。网络营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整睢县建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联建站从事“睢县网站设计”,“睢县网站推广”以来,每个客户项目都认真落实执行。

//布局文件


    
//MainActivity类package com.avi.myapplication5.app;

import android.app.Activity;
import android.os.Bundle;

public class MainActivity extends Activity{

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

    }


}//DrawActivity类
package com.avi.myapplication5.app;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;


/**
 * Created by Administrator on 14-4-18.
 */
public class DrawActivity extends View implements View.OnTouchListener{
    float PI=(float)Math.PI;//PI=3.1415那个什么的每次调用(float)Math.PI太麻烦,自定义一个。
    float canvasWidth,canvasHeight;//画布宽、高
    float width,height;//自定义长宽
    float left,up;//自定义左上角位置
    public DrawActivity(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    @Override
    protected void onDraw(Canvas canvas){
        super.onDraw(canvas);
        //开始一定要先调用Init()初始化参数。我自定义的参数没有默认值。
        Init(canvas);
        Render(canvas);
    }
    @Override
    public boolean onTouch(View view, MotionEvent event) {
        return false;
    }
    //初始化全局参数。
    //建议不要在其它函数里更改在这里初始化的参数,以免得不出正确结果
    void Init(Canvas canvas){
        //获取画布宽、高
        canvasWidth=(float)canvas.getWidth();
        canvasHeight=(float)canvas.getHeight();
        //自定义长宽
        width=2*PI;height=2*PI*canvasHeight/canvasWidth;
        // 自定义左上角位置
        left=-width/2;up=height/2;
    }
    //渲染画面。
    //画图步骤在这里。
    void Render(Canvas canvas){
        //新建画笔
        Paint paint=new Paint();
        //画网格线。
        paint.setARGB(255, 255, 0, 0);
        DrawGrid(canvas,0.3f,0.3f,paint);
        //画坐标线。
        paint.setARGB(255,0,0,0);
        DrawCoord(canvas,paint);
        //显示横、纵坐标轴名称和原点名称。(重要提示:这里就是你想要的新东西)
        paint.setARGB(255,100,100,100);
        DrawCoordName(canvas,paint,"t","f(t)","O");
        //画曲线
        DrawCurve(canvas, paint);
    }
    //画网格线。
    //要先画网格再画坐标,不然网格线会把坐标线覆盖掉从而看不到坐标线
    //dx,dy:
    void DrawGrid(Canvas canvas,float dx,float dy,Paint paint){
        //画纵向网格线
        //左侧
        float x=0;
        while (x>left){
            canvas.drawLine(PX(x),PY(up),PX(x),PY(up-height),paint);
            x-=dx;
        }
        //右侧
        x=0;
        while (xup-height){
            canvas.drawLine(PX(left),PY(y),PX(left+width),PY(y),paint);
            y-=dy;
        }
    }
    //画坐标线。
    void DrawCoord(Canvas canvas,Paint paint){
        //画x,y坐标
        canvas.drawLine(PX(left),PY(0f),PX(left+width),PY(0f),paint);
        canvas.drawLine(PX(0f),PY(up),PX(0f),PY(up-height),paint);
    }
    //(重要提示:这里就是你想要的新东西)
    //显示横、纵坐标轴名称和原点名称。
    void DrawCoordName(Canvas canvas,Paint paint,String xAxisName,String yAxisName,String originName){
        //设置文字大小
        paint.setTextSize(40f);
        //在适当位置显示x,y,O名称
        canvas.drawText(xAxisName,PX(left+width)-30f,PY(0f)+30f,paint);
        canvas.drawText(yAxisName,PX(0f),PY(up)+30f,paint);
        canvas.drawText(originName,PX(0f),PY(0f)+30f,paint);

    }
    //画点函数。使用自定义坐标。
    void DrawPoint(Canvas canvas,float x,float y,Paint paint){
        canvas.drawPoint(PX(x),PY(y),paint);
    }
    //(重要提示:所有你想画的曲线都在这里进行。)
    //画曲线函数。
    //使用画布坐标。所以要调用PX(x),PY(y)把自定义坐标里的量(如x,y)转换成画布坐标。
    void DrawCurve(Canvas canvas,Paint paint){//绘制曲线

        paint.setARGB(255,0,0,255);
        for(float x=left;x

以上是“如何使用android画函数曲线”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!


本文题目:如何使用android画函数曲线
地址分享:http://cdkjz.cn/article/geceip.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220