如何使用android畫函數曲線

這篇文章主要介紹如何使用android畫函數曲線,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

10余年的睢縣網站建設經驗,針對設計、前端、開發、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。網絡營銷推廣的優勢是能夠根據用戶設備顯示端的尺寸不同,自動調整睢縣建站的顯示方式,使網站能夠適用不同顯示終端,在瀏覽器中調整網站的寬度,無論在任何一種瀏覽器上瀏覽網站,都能展現優雅布局與設計,從而大程度地提升瀏覽體驗。創新互聯建站從事“睢縣網站設計”,“睢縣網站推廣”以來,每個客戶項目都認真落實執行。

//布局文件
<FrameLayout 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"
    tools:context="com.avi.myapplication5.app.MainActivity">

    <com.avi.myapplication5.app.DrawActivity
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
</FrameLayout>//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 (x<width+left){
            canvas.drawLine(PX(x),PY(up),PX(x),PY(up-height),paint);
            x+=dx;
        }
        //畫橫向網格線
        //上側
        float y=0;
        while (y<up){
            canvas.drawLine(PX(left),PY(y),PX(left+width),PY(y),paint);
            y+=dy;
        }
        //下側
        y=0;
        while (y>up-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<left+width;x+=0.001f){
            float y=(float)Math.sin(x);
            DrawPoint(canvas,x,y,paint);

        }
        //因為x,y是自定義坐標,canvas.drawText()是系統提供的函數,
        // 所以要調用PX(),PY()將(PI/2,sin(PI/2))轉換成畫布坐標;
        canvas.drawText("f(t)=sin(t)",PX(PI/2),PY((float)Math.sin(PI/2)),paint);
    }
    //將自定義坐標轉換成畫布坐標的函數,
    //當要用自定義坐標在系統提供的函數上繪圖時,要調用這兩個函數把自定義坐標轉換成畫布坐標
    float PX(float x){
        return (x-left)*canvasWidth/width;
    }
    float PY(float y){
        return (up-y)*canvasHeight/height;
    }


}

以上是“如何使用android畫函數曲線”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創新互聯行業資訊頻道!

本文名稱:如何使用android畫函數曲線
當前路徑:http://m.kartarina.com/article8/geceip.html

成都網站建設公司_創新互聯,為您提供定制網站、網站營銷、網頁設計公司、標簽優化關鍵詞優化搜索引擎優化

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

手機網站建設
主站蜘蛛池模板: 精品无码中文视频在线观看| 无码AV天堂一区二区三区| 国产AV无码专区亚洲AWWW| 久久亚洲AV永久无码精品| 亚洲精品无码av人在线观看 | 久久久无码人妻精品无码| 久久无码无码久久综合综合| 亚洲AV无码无限在线观看不卡 | 精品久久久久久无码专区不卡 | 国产亚洲精久久久久久无码AV| 亚洲AV无码一区二区三区系列| 国产精品亚洲专区无码唯爱网| 国产成人无码区免费内射一片色欲| 在线观看无码AV网址| 少妇性饥渴无码A区免费 | 人妻无码一区二区三区四区| 亚洲AV无码一区东京热| 亚洲国产综合无码一区二区二三区| 亚洲熟妇无码爱v在线观看| 亚洲中文字幕无码永久在线| 亚洲AV日韩AV永久无码色欲| 无码日韩精品一区二区人妻| 无码射肉在线播放视频| 久久亚洲AV无码西西人体| 无码任你躁久久久久久久 | 亚洲熟妇无码av另类vr影视| 亚洲av无码精品网站| 日韩人妻无码一区二区三区综合部| 无码一区二区三区爆白浆| 久久精品无码一区二区日韩AV| 亚洲AV无码资源在线观看| 亚洲人AV在线无码影院观看| 精品欧洲AV无码一区二区男男 | 13小箩利洗澡无码视频网站免费| 亚洲av永久中文无码精品 | 69堂人成无码免费视频果冻传媒 | 无码人妻一区二区三区免费看| 国产台湾无码AV片在线观看| 成人无码一区二区三区| 亚洲a∨无码一区二区| 亚洲精品无码久久久久牙蜜区|