4
ফোকাস
1271
অনুসারী

কৌশল অঙ্কন নকশা সহজতর করতে KLineChart ফাংশন ব্যবহার করুন

তৈরি: 2022-07-01 15:54:06, আপডেট করা হয়েছে: 2023-09-18 20:11:05
comments   3
hits   2617

কৌশল অঙ্কন নকশা সহজতর করতে KLineChart ফাংশন ব্যবহার করুন

কৌশল অঙ্কন নকশা সহজতর করতে KLineChart ফাংশন ব্যবহার করুন

কৌশল ডিজাইন করার সময়, জাভাস্ক্রিপ্ট বা পাইথন ব্যবহার করে কৌশল লেখার সময় প্রায়ই কৌশল চার্ট ডিসপ্লে ডিজাইন করা প্রয়োজন। যে ব্যবহারকারীরা প্রোগ্রামিং বা FMZ প্ল্যাটফর্মের দ্বারা ব্যবহৃত চার্ট লাইব্রেরির সাথে পরিচিত নন তারা প্রায়ই কাস্টম চার্টে ছবি আঁকার জন্য কোড ডিজাইন দ্বারা সমস্যায় পড়েন। তাহলে কিভাবে আপনি অল্প পরিমাণ কোড লিখতে পারেন এবং একটি সমৃদ্ধ কৌশল চার্ট আঁকতে পারেন?

এই সহজ কিন্তু শক্তিশালী অঙ্কন পদ্ধতিটি পাইন ভাষায় দেখা যায়, যা তার সমৃদ্ধ অঙ্কন ফাংশনের জন্য বিখ্যাত। যদি পাইন ভাষার অঙ্কন ইন্টারফেস জাভাস্ক্রিপ্ট এবং পাইথন ভাষার কৌশলগুলির সাথে সংযুক্ত করা যায় তবে এটি কৌশলগুলি ডিজাইন করার ক্ষেত্রে বিকাশকারীদের অঙ্কন ফাংশনকে ব্যাপকভাবে সহজ করবে। অতএব, এই চাহিদার উপর ভিত্তি করে, FMZ প্ল্যাটফর্ম কাস্টম অঙ্কন ফাংশন আপগ্রেড এবং এর ব্যবহার প্রসারিত করেছেKLineChartফাংশনটি কাস্টম চার্ট অঙ্কন সম্পাদন করে। আপনি API ডকুমেন্টেশনটি দেখতে পারেন: https://www.fmz.com/api#klinechart

ট্রানজিশন করার জন্য প্রথমে জাভাস্ক্রিপ্ট ভাষা ব্যবহার করে একটি সহজ উদাহরণ লিখি।

সহজ উদাহরণ

/*backtest
start: 2022-03-21 09:00:00
end: 2022-06-21 15:00:00
period: 30m
basePeriod: 15m
exchanges: [{"eid":"Binance","currency":"BTC_USDT"}]
*/

function main() {
    var c = KLineChart()
    while (true) {
        var bars = _C(exchange.GetRecords)
        for (var i = 0 ; i < bars.length ; i++) {
            var bar = bars[i]
            c.begin(bar)
            c.plot(bar.Volume, "volume")
            c.close()
        }
        Sleep(1000)
    }
}

এই উদাহরণটি খুবই সহজ এটি কৌশলটির কাস্টম অঙ্কন এলাকায় কে-লাইন চার্ট আঁকে এবং চার্টের সাব-ইমেজ অবস্থানে প্রতিটি কে-লাইন বার-এর সাথে সম্পর্কিত ভলিউম বক্ররেখা আঁকে।

কৌশল অঙ্কন নকশা সহজতর করতে KLineChart ফাংশন ব্যবহার করুন

কোডে আমরা প্রথমে ব্যবহার করিvar c = KLineChart()একটি চার্ট অবজেক্ট তৈরি করুন এবং তারপর আঁকার জন্য এর পদ্ধতিগুলি ব্যবহার করুন। তারপর লুপে, আমরা কে-লাইন ডেটা (অ্যারে স্ট্রাকচার) পাই এবং কে-লাইন অ্যারে অতিক্রম করি। আপনি উদাহরণ হিসাবে ট্রাভার্স করার জন্য একটি সহজ লুপ ব্যবহার করতে পারেন, অথবা আপনি অতিক্রম করার জন্য অন্যান্য পদ্ধতি ব্যবহার করতে পারেন।

অঙ্কন অপারেশনগুলি থেকে করা উচিতc.begin(bar)ফাংশন শুরু হয়,c.close()ফাংশন শেষ।begincloseফাংশনগুলি চার্ট অবজেক্টের সমস্ত পদ্ধতি c. এর পরে, সর্বাধিক ব্যবহৃত অঙ্কন ফাংশন ব্যবহার করুনplotপ্রতিটি বারে ভলিউম বক্ররেখা আঁকুন।

আরও জটিল উদাহরণ

ধরুন আমরা বলিঞ্জার ইন্ডিকেটর দিয়ে একটি চার্ট ডিজাইন করতে চাই। ওহ হ্যাঁ! এটি প্রতিটি বারের জন্য একটি ট্রেডিং ভলিউম চার্ট সহ আসে, যা এইভাবে ডিজাইন করা যেতে পারে:

/*backtest
start: 2022-03-21 09:00:00
end: 2022-06-21 15:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Binance","currency":"BTC_USDT"}]
*/

function main() {
    var c = KLineChart()

    // 策略主循环
    while(true) {
        // 轮询间隔
        Sleep(500)
        
        // 获取K线数据
        let bars = exchange.GetRecords()
        if (!bars || bars.length <= 20) {
            continue
        }
        
        // 计算布林指标
        var boll = TA.BOLL(bars)
        
        bars.forEach(function(bar, index) {
            c.begin(bar)
            // 画图操作
            c.plot(boll[0][index], "Boll_Up", {overlay: true})     // 画在图表主图
            c.plot(boll[1][index], "Boll_Mid", {overlay: true})    // 画在图表主图
            c.plot(boll[2][index], "Boll_Down", {overlay: true})   // 画在图表主图
            c.plot(bar.Volume, "volume")                           // 画在图表副图
            c.close()
        })
    
        // 策略交易逻辑
        // ...
        // ..
    }
}

আপনি কোডটিতে দেখতে পারেন যে FMZ প্ল্যাটফর্মে আমাদের ব্যাকটেস্ট কনফিগারেশন তথ্য হল:

/*backtest
start: 2022-03-21 09:00:00
end: 2022-06-21 15:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Binance","currency":"BTC_USDT"}]
*/

এই কনফিগারেশনটি Binance স্পট এক্সচেঞ্জ অবজেক্ট ব্যবহার করে ব্যাকটেস্ট করা হয়। ব্যাকটেস্টের ফলাফল চিত্রে দেখানো হয়েছে:

কৌশল অঙ্কন নকশা সহজতর করতে KLineChart ফাংশন ব্যবহার করুন

এটি দেখা যায় যে আমরা পাইনের অঙ্কন পদ্ধতি ব্যবহার করি, যা জাভাস্ক্রিপ্ট ভাষায় অঙ্কন কোডটিকে ব্যাপকভাবে সরল করে।

তথ্য লিখুন যেমন সূচক এবং গ্রাফ আঁকা

প্ল্যাটফর্ম স্ট্র্যাটেজি স্কোয়ারের কৌশল উদাহরণ এবং API নথিতে কে-লাইন ডেটা প্রাপ্ত করা এবং সূচকগুলি গণনা করা খুব সাধারণ, এবং সেগুলিও খুব সহজ।

        // 获取K线数据
        let bars = exchange.GetRecords()
        if (!bars || bars.length <= 20) {   
            // 如果获取K线失败,即!bar为真则执行continue,忽略之后的代码,重新执行循环
            // 如果bars.length小于等于20,即K线BAR(柱)数量小于20,无法计算指标,也执行continue
            continue
        }
        
        // 计算布林指标
        var boll = TA.BOLL(bars)

বলিঙ্গার ইন্ডিকেটর ক্যালকুলেশন ফাংশন TA.BOLL, যদি বলিঙ্গার ইন্ডিকেটর প্যারামিটার নির্দিষ্ট করা না থাকে, ডিফল্ট প্যারামিটার ব্যবহার করা হবে।BOLL(20, 2). বলিঙ্গার নির্দেশকের তিনটি লাইন আছে, তাই TA.BOLL ফাংশন দ্বারা প্রত্যাবর্তিত ডেটা একটি দ্বি-মাত্রিক অ্যারে। বোল[0]、boll[1]、boll[2] বোল অ্যারের তিনটি উপাদান তাদের প্রত্যেকটি একটি লাইনকে উপস্থাপন করে এবং একটি অ্যারে।

  • boll[0]: বলিঙ্গার ব্যান্ডস অনলাইন
  • boll[1]: বলিঙ্গার ব্যান্ডস মিডল লাইন
  • boll[2]: বলিঙ্গার ব্যান্ড অফলাইন

তারপর আমরা দেখব কিভাবে কে-লাইন ডেটার ভলিউম আঁকতে হয়, অর্থাৎ ট্রেডিং ভলিউম এবং চার্টে গণনা করা বলিঙ্গার সূচক ডেটা।

আমরা বার দ্বারা কে-লাইন ডেটা বার আঁকি, তাই আমাদের পুরো কে-লাইন অ্যারেটি অতিক্রম করতে হবে, অর্থাৎ কোডের বার অ্যারেটি অতিক্রম করতে হবে। এখানে ব্যবহার করা হয়forEachএকটি ফর লুপ ব্যবহার করে মেথড ট্রাভার্সালও ট্রাভার্স করা যায়।

        bars.forEach(function(bar, index) {
            c.begin(bar)
            // 画图操作
            c.plot(boll[0][index], "Boll_Up", {overlay: true})     // {overlay: true}参数控制,画在图表主图
            c.plot(boll[1][index], "Boll_Mid", {overlay: true})    // 画在图表主图
            c.plot(boll[2][index], "Boll_Down", {overlay: true})   // 画在图表主图
            c.plot(bar.Volume, "volume")                           // 画在图表副图
            c.close()
        })

এটি লক্ষ করা উচিত যে আপনি যখনই একটি বারে একটি চার্ট অঙ্কন অপারেশন শুরু করবেন, আপনাকে অবশ্যই প্রথমেই করতে হবেc.begin(bar)ফাংশন কল,beginফাংশনটি আমাদের চার্ট অবজেক্টের একটি পদ্ধতি c. অঙ্কন অপারেশন শেষ হলে, আপনাকে কল করতে হবেc.close(). বিদ্যমানbeginফাংশন যোগফলcloseফাংশনগুলির মধ্যে অঙ্কন ফাংশনগুলিকে আমরা বলি যেগুলি পাইন ভাষার অঙ্কন পদ্ধতির অনুরূপ। সমর্থন:barcolor bgcolor plot fill hline plotarrow plotshape plotchar plotcandle signal, আপনি লাইন, তীর, চিহ্নিত তথ্য, ইত্যাদি আঁকতে পারেন। এই ফাংশনগুলির প্যারামিটারগুলি পাইন ভাষার সাথে সামঞ্জস্যপূর্ণ এবং অঙ্কন ফাংশনগুলিও সামঞ্জস্যপূর্ণ।

ট্রেডিং সিগন্যাল তীর, চিহ্ন, অনুভূমিক রেখা এবং অন্যান্য অঙ্কন যোগ করুন

উপরের বলিঙ্গার নির্দেশক অঙ্কন উদাহরণে কিছু ট্রেডিং সংকেত তীর, মার্কার এবং অনুভূমিক রেখা যোগ করুন।

/*backtest
start: 2022-03-21 09:00:00
end: 2022-06-21 15:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Binance","currency":"BTC_USDT"}]
*/

function main() {
    var c = KLineChart()

    // 策略主循环
    while(true) {
        // 轮询间隔
        Sleep(500)
        
        // 获取K线数据
        let bars = exchange.GetRecords()
        if (!bars || bars.length <= 20) {
            continue
        }
        
        // 计算布林指标
        var boll = TA.BOLL(bars)
        
        bars.forEach(function(bar, index) {
            c.begin(bar)
            // 画图操作
            c.plot(boll[0][index], "Boll_Up", {overlay: true})     // 画在图表主图
            c.plot(boll[1][index], "Boll_Mid", {overlay: true})    // 画在图表主图
            c.plot(boll[2][index], "Boll_Down", {overlay: true})   // 画在图表主图
            c.plot(bar.Volume, "volume")                           // 画在图表副图
            
            c.hline(bar.Open, {overlay: true})                                         // 水平线
            c.plotarrow(bar.Close - bar.Open, {overlay: true})                         // 箭头
            c.plotshape(bar.Close - bar.Open > 0, {style: 'square', overlay: true})    // 画方块标记
            c.plotchar(bar.Close - bar.Open < 0, {char: '❄', size: "20px", overlay: true})           // 画出字符❄
            if (boll[0][index] && bar.Close > boll[0][index]) {
                c.signal("long", bar.Close, 1.5)
            } else if (boll[2][index] && bar.Close < boll[2][index]) {
                c.signal("closelong", bar.Close, 1.5)
            }
            
            c.close()
        })
    
        // 策略交易逻辑
        // ...
        // ..
    }
}

কৌশল অঙ্কন নকশা সহজতর করতে KLineChart ফাংশন ব্যবহার করুন

যেহেতু পাইন ভাষা কৌশল অর্ডার অপারেশন স্বয়ংক্রিয়ভাবে চার্টে সংকেত চিহ্নিত করবে, তাইKLineChartফাংশন দ্বারা তৈরি চার্ট অবজেক্ট ক্রয়-বিক্রয় সংকেত মার্কার আঁকার জন্য একটি ফাংশন প্রসারিত করে:c.signal

চার্ট কনফিগারেশন অবজেক্ট

আপনি চার্ট শৈলী কনফিগার করার জন্য একটি কাঠামো ঘোষণা করতে পারেন, উদাহরণস্বরূপ, নিম্নলিখিত চার্টসিএফজি ভেরিয়েবল একটি গ্রিড লাইনের কনফিগারেশন তথ্য উপস্থাপন করে।

    var chartCfg = {
        grid: {
            show: true,
            // 网格水平线
            horizontal: {
                show: true,
                size: 2,
                color: '#FF0000',    // 水平网格线的颜色
                // 'solid'|'dash'
                style: 'dash',       // 线的类型
                dashValue: [2, 2]
            },
   	        // 网格垂直线
            vertical: {
                show: true,
                size: 2,
                color: '#32CD32',
                // 'solid'|'dash'
                style: 'solid',
                dashValue: [2, 2]
            }
        },
    }

চার্ট কনফিগারেশন অবজেক্ট হল একটি ডাটা স্ট্রাকচার যা চার্টের কিছু বৈশিষ্ট্য, চেহারা ইত্যাদি সেট করে, উদাহরণে ব্যবহৃত কনফিগারেশন হল একটি গ্রিড লাইন স্টাইল কনফিগারেশন। অনেক অপশন আছে যা কনফিগার এবং পরিবর্তন করা যেতে পারে, যেমন X-অক্ষ এবং Y-অক্ষ সম্পর্কিত সেটিংস, কার্সার লাইন সেটিংস, প্রম্পট তথ্য সেটিংস, প্রযুক্তিগত নির্দেশক শৈলী সেটিংস, কে-লাইন বার শৈলী সেটিংস ইত্যাদি।

অবশ্য এসবের সাথে পরিচিত না হলে ফোন করার আগেKLineChartএকটি চার্ট অবজেক্ট তৈরি করার সময় ফাংশনটি চার্ট কনফিগারেশন অবজেক্টে পাস করার প্রয়োজন নেই। তারপর তৈরি করা চার্টটি ডিফল্ট শৈলী। FMZ প্ল্যাটফর্মের API ফাংশন ব্যবহার করাKLineChartফাংশন চার্ট অবজেক্ট তৈরি করে:

var c = KLineChart(chartCfg)

গ্রিড লাইন আঁকার জন্য টেস্ট কোড:

/*backtest
start: 2022-03-21 09:00:00
end: 2022-06-21 15:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Binance","currency":"BTC_USDT"}]
*/

function main() {
    var chartCfg = {
        grid: {
            show: true,
            // 网格水平线
            horizontal: {
                show: true,
                size: 2,
                color: '#FF0000',
                // 'solid'|'dash'
                style: 'dash',
                dashValue: [2, 2]
            },
   	        // 网格垂直线
            vertical: {
                show: true,
                size: 2,
                color: '#32CD32',
                // 'solid'|'dash'
                style: 'solid',
                dashValue: [2, 2]
            }
        },
    }

    var c = KLineChart(chartCfg)

    // 策略主循环
    while(true) {
        // 轮询间隔
        Sleep(500)
        
        // 获取K线数据
        var bars = _C(exchange.GetRecords)
        bars.forEach(function(bar, index) {
            c.begin(bar)
            c.close()
        })
    
        // 策略交易逻辑
        // ...
        // ..
    }
}

কৌশল অঙ্কন নকশা সহজতর করতে KLineChart ফাংশন ব্যবহার করুন

চার্ট কনফিগারেশন শৈলী উদাহরণ

চার্ট কনফিগারেশন শৈলী সেটিংস উল্লেখ করতে ব্যবহার করা যেতে পারে।

{
    // 网格线
    grid: {
        show: true,
        // 网格水平线
        horizontal: {
            show: true,
            size: 1,
            color: '#393939',
            // 'solid'|'dash'
            style: 'dash',
            dashValue: [2, 2]
        },
        // 网格垂直线
        vertical: {
            show: false,
            size: 1,
            color: '#393939',
            // 'solid'|'dash'
            style: 'dash',
            dashValue: [2, 2]
        }
    },
    // 蜡烛图
    candle: {
        // 蜡烛图上下间距,大于1为绝对值,大于0小余1则为比例
        margin: {
            top: 0.2,
            bottom: 0.1
        },
        // 蜡烛图类型 'candle_solid'|'candle_stroke'|'candle_up_stroke'|'candle_down_stroke'|'ohlc'|'area'
        type: 'candle_solid',
        // 蜡烛柱
        bar: {
            upColor: '#26A69A',
            downColor: '#EF5350',
            noChangeColor: '#888888'
        },
        // 面积图
        area: {
            lineSize: 2,
            lineColor: '#2196F3',
            value: 'close',
            backgroundColor: [{
                offset: 0,
                color: 'rgba(33, 150, 243, 0.01)'
            }, {
                offset: 1,
                color: 'rgba(33, 150, 243, 0.2)'
            }]
        },
        priceMark: {
            show: true,
            // 最高价标记
            high: {
                show: true,
                color: '#D9D9D9',
                textMargin: 5,
                textSize: 10,
                textFamily: 'Helvetica Neue',
                textWeight: 'normal'
            },
            // 最低价标记
            low: {
                show: true,
                color: '#D9D9D9',
                textMargin: 5,
                textSize: 10,
                textFamily: 'Helvetica Neue',
                textWeight: 'normal',
            },
            // 最新价标记
            last: {
                show: true,
                upColor: '#26A69A',
                downColor: '#EF5350',
                noChangeColor: '#888888',
                line: {
                    show: true,
                    // 'solid'|'dash'
                    style: 'dash',
                    dashValue: [4, 4],
                    size: 1
                },
                text: {
                    show: true,
                    size: 12,
                    paddingLeft: 2,
                    paddingTop: 2,
                    paddingRight: 2,
                    paddingBottom: 2,
                    color: '#FFFFFF',
                    family: 'Helvetica Neue',
                    weight: 'normal',
                    borderRadius: 2
                }
            }
        },
        // 提示
        tooltip: {
            // 'always' | 'follow_cross' | 'none'
            showRule: 'always',
            // 'standard' | 'rect'
            showType: 'standard',
            labels: ['时间', '开', '收', '高', '低', '成交量'],
            values: null,
            defaultValue: 'n/a',
            rect: {
                paddingLeft: 0,
                paddingRight: 0,
                paddingTop: 0,
                paddingBottom: 6,
                offsetLeft: 8,
                offsetTop: 8,
                offsetRight: 8,
                borderRadius: 4,
                borderSize: 1,
                borderColor: '#3f4254',
                backgroundColor: 'rgba(17, 17, 17, .3)'
            },
            text: {
                size: 12,
                family: 'Helvetica Neue',
                weight: 'normal',
                color: '#D9D9D9',
                marginLeft: 8,
                marginTop: 6,
                marginRight: 8,
                marginBottom: 0
            }
        }
    },
    // 技术指标
    technicalIndicator: {
        margin: {
            top: 0.2,
            bottom: 0.1
        },
        bar: {
            upColor: '#26A69A',
            downColor: '#EF5350',
            noChangeColor: '#888888'
        },
        line: {
            size: 1,
            colors: ['#FF9600', '#9D65C9', '#2196F3', '#E11D74', '#01C5C4']
        },
        circle: {
            upColor: '#26A69A',
            downColor: '#EF5350',
            noChangeColor: '#888888'
        },
        // 最新值标记
        lastValueMark: {
            show: false,
            text: {
                show: false,
                color: '#ffffff',
                size: 12,
                family: 'Helvetica Neue',
                weight: 'normal',
                paddingLeft: 3,
                paddingTop: 2,
                paddingRight: 3,
                paddingBottom: 2,
                borderRadius: 2
            }
        },
        // 提示
        tooltip: {
            // 'always' | 'follow_cross' | 'none'
            showRule: 'always',
            // 'standard' | 'rect'
            showType: 'standard',
            showName: true,
            showParams: true,
            defaultValue: 'n/a',
            text: {
                size: 12,
                family: 'Helvetica Neue',
                weight: 'normal',
                color: '#D9D9D9',
                marginTop: 6,
                marginRight: 8,
                marginBottom: 0,
                marginLeft: 8
            }
        }
    },
    // x轴
    xAxis: {
        show: true,
        height: null,
        // x轴线
        axisLine: {
            show: true,
            color: '#888888',
            size: 1
        },
        // x轴分割文字
        tickText: {
            show: true,
            color: '#D9D9D9',
            family: 'Helvetica Neue',
            weight: 'normal',
            size: 12,
            paddingTop: 3,
            paddingBottom: 6
        },
        // x轴分割线
        tickLine: {
            show: true,
            size: 1,
            length: 3,
            color: '#888888'
        }
    },
    // y轴
    yAxis: {
        show: true,
        width: null,
        // 'left' | 'right'
        position: 'right',
        // 'normal' | 'percentage' | 'log'
        type: 'normal',
        inside: false,
        reverse: false,
        // y轴线
        axisLine: {
            show: true,
            color: '#888888',
            size: 1
        },
        // y轴分割文字
        tickText: {
            show: true,
            color: '#D9D9D9',
            family: 'Helvetica Neue',
            weight: 'normal',
            size: 12,
            paddingLeft: 3,
            paddingRight: 6
        },
        // y轴分割线
        tickLine: {
            show: true,
            size: 1,
            length: 3,
            color: '#888888'
        }
    },
    // 图表之间的分割线
    separator: {
        size: 1,
        color: '#888888',
        fill: true,
        activeBackgroundColor: 'rgba(230, 230, 230, .15)'
    },
    // 十字光标
    crosshair: {
        show: true,
        // 十字光标水平线及文字
        horizontal: {
            show: true,
            line: {
                show: true,
                // 'solid'|'dash'
                style: 'dash',
                dashValue: [4, 2],
                size: 1,
                color: '#888888'
            },
            text: {
                show: true,
                color: '#D9D9D9',
                size: 12,
                family: 'Helvetica Neue',
                weight: 'normal',
                paddingLeft: 2,
                paddingRight: 2,
                paddingTop: 2,
                paddingBottom: 2,
                borderSize: 1,
                borderColor: '#505050',
                borderRadius: 2,
                backgroundColor: '#505050'
            }
        },
        // 十字光标垂直线及文字
        vertical: {
            show: true,
            line: {
                show: true,
                // 'solid'|'dash'
                style: 'dash',
                dashValue: [4, 2],
                size: 1,
                color: '#888888'
            },
            text: {
                show: true,
                color: '#D9D9D9',
                size: 12,
                family: 'Helvetica Neue',
                weight: 'normal',
                paddingLeft: 2,
                paddingRight: 2,
                paddingTop: 2,
                paddingBottom: 2,
                borderSize: 1,
                borderColor: '#505050',
                borderRadius: 2,
                backgroundColor: '#505050'
            }
        }
    },
    // 图形
    shape: {
        point: {
            backgroundColor: '#2196F3',
            borderColor: '#2196F3',
            borderSize: 1,
            radius: 4,
            activeBackgroundColor: '#2196F3',
            activeBorderColor: '#2196F3',
            activeBorderSize: 1,
            activeRadius: 6
        },
        line: {
            // 'solid'|'dash'
            style: 'solid'
            color: '#2196F3',
            size: 1,
            dashValue: [2, 2]
        },
        polygon: {
            // 'stroke'|'fill'
            style: 'stroke',
            stroke: {
                // 'solid'|'dash'
                style: 'solid',
                size: 1,
                color: '#2196F3',
                dashValue: [2, 2]
            },
            fill: {
                color: 'rgba(33, 150, 243, 0.1)'
            }
        },
        arc: {
            // 'stroke'|'fill'
            style: 'stroke',
            stroke: {
                // 'solid'|'dash'
                style: 'solid',
                size: 1,
                color: '#2196F3',
                dashValue: [2, 2]
            },
            fill: {
                color: '#2196F3'
            }
        },
        text: {
            style: 'fill',
            color: '#2196F3',
            size: 12,
            family: 'Helvetica Neue',
            weight: 'normal',
            offset: [0, 0]
        }
    },
    annotation: {
        // 'top' | 'bottom' | 'point'
        position: 'top',
        offset: [20, 0]
        symbol: {
            // 'diamond' | 'circle' | 'rect' | 'triangle' | 'custom' | 'none'
            type: 'diamond',
            size: 8,
            color: '#2196F3',
            activeSize: 10,
            activeColor: '#FF9600'
        }
    },
    tag: {
        // 'top' | 'bottom' | 'point'
        position: 'point',
        offset: 0,
        line: {
            show: true,
            style: LineStyle.DASH,
            dashValue: [4, 2],
            size: 1,
            color: '#2196F3'
        },
        text: {
            color: '#FFFFFF',
            backgroundColor: '#2196F3',
            size: 12,
            family: 'Helvetica Neue',
            weight: 'normal',
            paddingLeft: 2,
            paddingRight: 2,
            paddingTop: 2,
            paddingBottom: 2,
            borderRadius: 2,
            borderSize: 1,
            borderColor: '#2196F3'
        },
        mark: {
            offset: 0,
            color: '#FFFFFF',
            backgroundColor: '#2196F3',
            size: 12,
            family: 'Helvetica Neue',
            weight: 'normal',
            paddingLeft: 2,
            paddingRight: 2,
            paddingTop: 2,
            paddingBottom: 2,
            borderRadius: 2,
            borderSize: 1,
            borderColor: '#2196F3'
        }
    }
}

এটি কি কৌশল অঙ্কন এবং নকশাকে সহজ করে তোলে না?