All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.davaded.echarts.data.BasicData Maven / Gradle / Ivy

/*
 * The MIT License (MIT)
 *
 * Copyright (c) 2014-2015 [email protected]
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */

package com.github.davaded.echarts.data;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

import com.github.davaded.echarts.code.MarkType;
import com.github.davaded.echarts.code.Symbol;
import com.github.davaded.echarts.style.ItemStyle;
import com.github.davaded.echarts.style.TextStyle;

import lombok.Getter;
import lombok.Setter;

/**
 * Description: BasicData
 *
 * @author liuzh
 */
@Getter
@Setter
public abstract class BasicData implements Serializable {

    private static final long serialVersionUID = 3510060011221090087L;

    private String name;
    private String text;
    private Object value;
    /**
     * 饼图、雷达图、力导、和弦图使用x,y
     */
    private Object x;
    private Object y;
    /**
     * 在存在直角坐标系的图表如折线、柱形、K线、散点图中
     * 除了通过直接指定位置外,如果希望标注基于直角系的定位,可以通过xAxis,yAxis
     */
    private Integer xAxis;
    private Integer yAxis;
    private MarkType type;
    private Object symbol;
    private Object symbolSize;
    private ItemStyle itemStyle;
    /**
     * 特殊样式
     *
     * @see TextStyle
     */
    private TextStyle textStyle;

    /**
     * 基础数据
     * 构造函数
     */
    public BasicData() {
    }

    /**
     * 基础数据
     * 构造函数,参数:name
     *
     * @param name 名字
     */
    protected BasicData(String name) {
        this.name = name;
    }

    /**
     * 基础数据
     * 构造函数,参数:name,value
     *
     * @param name  名字
     * @param value 价值
     */
    public BasicData(String name, Object value) {
        this.name = name;
        this.value = value;
    }

    /**
     * 基础数据
     * 构造函数,参数:name,symbol,symbolSize
     *
     * @param name       名字
     * @param symbol     符号
     * @param symbolSize 符号大小
     */
    public BasicData(String name, Object symbol, Object symbolSize) {
        this.name = name;
        this.symbol = symbol;
        this.symbolSize = symbolSize;
    }

    /**
     * 基础数据
     * 构造函数,参数:value,symbol
     *
     * @param value  价值
     * @param symbol 符号
     */
    public BasicData(Object value, Object symbol) {
        this.value = value;
        this.symbol = symbol;
    }

    /**
     * 基础数据
     * 构造函数,参数:value,symbol,symbolSize
     *
     * @param value      价值
     * @param symbol     符号
     * @param symbolSize 符号大小
     */
    public BasicData(Object value, Object symbol, Object symbolSize) {
        this.value = value;
        this.symbol = symbol;
        this.symbolSize = symbolSize;
    }

    /**
     * 文本样式
     * 获取textStyle值
     *
     * @return {@link TextStyle}
     */
    public TextStyle textStyle() {
        if (this.textStyle == null) {
            this.textStyle = new TextStyle();
        }
        return this.textStyle;
    }

    /**
     * 文本样式
     * 设置textStyle值
     *
     * @param textStyle 文本样式
     * @return {@link T}
     */
    public T textStyle(TextStyle textStyle) {
        this.textStyle = textStyle;
        return (T) this;
    }

    /**
     * 文本
     * 获取text值
     *
     * @return {@link String}
     */
    public String text() {
        return this.text;
    }

    /**
     * 文本
     * 设置text值
     *
     * @param text 文本
     * @return {@link T}
     */
    public T text(String text) {
        this.text = text;
        return (T) this;
    }

    /**
     * 名字
     * 获取name值
     *
     * @return {@link String}
     */
    public String name() {
        return this.name;
    }

    /**
     * 名字
     * 设置name值
     *
     * @param name 名字
     * @return {@link T}
     */
    public T name(String name) {
        this.name = name;
        return (T) this;
    }

    /**
     * 价值
     * 获取value值
     *
     * @return {@link Object}
     */
    public Object value() {
        return this.value;
    }

    /**
     * 价值
     * 设置value值
     *
     * @param value 价值
     * @return {@link T}
     */
    public T value(Object value) {
        this.value = value;
        return (T) this;
    }

    /**
     * 价值
     * 设置value值
     *
     * @param values 值
     * @return {@link T}
     */
    public T value(Object... values) {
        if (values == null || values.length == 0) {
            return (T) this;
        }
        if (this.value == null) {
            this.value = new ArrayList(values.length);
        }
        if (this.value instanceof List) {
            ((List) this.value).addAll(Arrays.asList(values));
        }
        return (T) this;
    }

    /**
     * X
     * 获取x值
     *
     * @return {@link Object}
     */
    public Object x() {
        return this.x;
    }

    /**
     * X
     * 设置x值
     *
     * @param x X
     * @return {@link T}
     */
    public T x(Object x) {
        this.x = x;
        return (T) this;
    }

    /**
     * 是
     * 获取y值
     *
     * @return {@link Object}
     */
    public Object y() {
        return this.y;
    }

    /**
     * 是
     * 设置y值
     *
     * @param y 是
     * @return {@link T}
     */
    public T y(Object y) {
        this.y = y;
        return (T) this;
    }

    /**
     * X轴
     * 获取xAxis值
     *
     * @return {@link Integer}
     */
    public Integer xAxis() {
        return this.xAxis;
    }

    /**
     * X轴
     * 设置xAxis值
     *
     * @param xAxis X轴
     * @return {@link T}
     */
    public T xAxis(Integer xAxis) {
        this.xAxis = xAxis;
        return (T) this;
    }

    /**
     * 和轴
     * 获取yAxis值
     *
     * @return {@link Integer}
     */
    public Integer yAxis() {
        return this.yAxis;
    }

    /**
     * 和轴
     * 设置yAxis值
     *
     * @param yAxis 和轴
     * @return {@link T}
     */
    public T yAxis(Integer yAxis) {
        this.yAxis = yAxis;
        return (T) this;
    }

    /**
     * 类型
     * 获取type值
     *
     * @return {@link MarkType}
     */
    public MarkType type() {
        return this.type;
    }

    /**
     * 类型
     * 设置type值
     *
     * @param type 类型
     * @return {@link T}
     */
    public T type(MarkType type) {
        this.type = type;
        return (T) this;
    }

    /**
     * 符号
     * 获取symbol值
     *
     * @return {@link Object}
     */
    public Object symbol() {
        return this.symbol;
    }

    /**
     * 符号
     * 设置symbol值
     *
     * @param symbol 符号
     * @return {@link T}
     */
    public T symbol(Object symbol) {
        this.symbol = symbol;
        return (T) this;
    }

    /**
     * 符号
     * 设置symbol值
     *
     * @param symbol 符号
     * @return {@link T}
     */
    public T symbol(Symbol symbol) {
        this.symbol = symbol;
        return (T) this;
    }

    /**
     * 符号大小
     * 获取symbolSize值
     *
     * @return {@link Object}
     */
    public Object symbolSize() {
        return this.symbolSize;
    }

    /**
     * 符号大小
     * 设置symbolSize值
     *
     * @param symbolSize 符号大小
     * @return {@link T}
     */
    public T symbolSize(Object symbolSize) {
        this.symbolSize = symbolSize;
        return (T) this;
    }

    /**
     * 项目样式
     * 获取itemStyle值
     *
     * @return {@link ItemStyle}
     */
    public ItemStyle itemStyle() {
        if (this.itemStyle == null) {
            this.itemStyle = new ItemStyle();
        }
        return this.itemStyle;
    }

    /**
     * 项目样式
     * 设置itemStyle值
     *
     * @param itemStyle 项目样式
     * @return {@link T}
     */
    public T itemStyle(ItemStyle itemStyle) {
        this.itemStyle = itemStyle;
        return (T) this;
    }
}