2016-04-18 20 views
5

Tôi đang sử dụng MPandroidchart cho thấy bảng xếp hạng dòng trong application.I tôi đã thêm mã sau đây để hiển thị Marker View, nhưng nó không được hiển thị trênMarkerView không hiển thị sử dụng MPAndroidChart

private void initializeChart(LineChart chart, String chartName) { 
    // Chart view 
    chart.setDrawGridBackground(false); 
    chart.setDescription(""); 
    chart.getLegend().setEnabled(true); 
    //chart.setTouchEnabled(false); 
    int color = getResources().getColor(R.color.white); 
    chart.getAxisLeft().setTextColor(color); // left y-axis 
    chart.getXAxis().setTextColor(color); 

    chart.setTouchEnabled(true); 
    CustomMarkerView mv = new CustomMarkerView(this.getActivity(), R.layout.marker_view_tv); 
    chart.setMarkerView(mv); 

    //X axis 
    XAxis xAxis = chart.getXAxis(); 
    xAxis.setPosition(XAxis.XAxisPosition.BOTTOM); 
    xAxis.setDrawGridLines(false); 
    xAxis.setDrawLabels(true); 

    //Y axis 
    YAxis leftAxis = chart.getAxisLeft(); 
    YAxis rightAxis = chart.getAxisRight(); 
    rightAxis.setDrawLabels(false); 
    rightAxis.setDrawGridLines(false); 
    leftAxis.setDrawLabels(true); 
    leftAxis.setDrawGridLines(false); 
    leftAxis.setStartAtZero(false); 

    SharedPreferences pref = PreferenceManager.getDefaultSharedPreferences(getActivity()); 


    leftAxis.setLabelCount(Constants.KEY_LINE_YAXIS_SCALECOUNT, true); 
    ChartItem item = CannonJsonParser.parseCanonJson(act, act.res); 
    int maxYVal = pref.getInt(Constants.KEY_YAXIS_VALUE, 0); 
    leftAxis.setAxisMaxValue(maxYVal); 
    leftAxis.setAxisMinValue(0); 
    setLineData(item, chartName); 
    // set data 
    chart.setData(lineData); 

    chart.getLegend().setEnabled(false); 
    //animate 
    //chart.animateX(2000, Easing.EasingOption.EaseInExpo); 
    chart.setDragEnabled(true); 
    chart.setScaleXEnabled(true); 
    chart.setScaleYEnabled(false); 
    chart.setHighlightPerDragEnabled(false); 
    chart.setHighlightPerTapEnabled(false); 


} 

My lớp CustomMarkerView

public class CustomMarkerView extends MarkerView { 
private TextView tvContent; 

public CustomMarkerView(Context context, int layoutResource) { 
    super(context, layoutResource); 

    tvContent = (TextView) findViewById(R.id.tvContent); 
} 

// callbacks everytime the MarkerView is redrawn, can be used to update the 
// content (user-interface) 
@Override 
public void refreshContent(Entry e, Highlight highlight) { 

    if (e instanceof CandleEntry) { 

     CandleEntry ce = (CandleEntry) e; 

     tvContent.setText("" + Utils.formatNumber(ce.getHigh(), 0, true)); 
    } else { 

     tvContent.setText("" + Utils.formatNumber(e.getVal(), 0, true)); 
    } 
} 

@Override 
public int getXOffset(float xpos) { 
    // this will center the marker-view horizontally 
    return -(getWidth()/2); 
} 

@Override 
public int getYOffset(float ypos) { 
    // this will cause the marker-view to be above the selected value 
    return -getHeight(); 
} 

}

Lưu ý: tôi đang sử dụng đoạn để hiển thị biểu đồ.

Trả lời

4

bạn MarkerView không được hiển thị vì bạn chưa nhấn mạnh mọi mục nhập trong biểu đồ của bạn. MarkerView chỉ được hiển thị cho các mục được tô sáng.

Vì bạn vô hiệu hóa các chức năng để làm nổi bật mục mỗi vòi (bằng cách gọi chart.setHighlightPerTapEnabled(false)), bạn chỉ có thể làm nổi bật giá trị theo chương trình, như thế này:

chart.highlightValue(...)

Thông tin thêm về rằng trong documentation.

1

thử này, lớp

import android.content.Context; 
import android.widget.TextView; 

import com.github.mikephil.charting.components.MarkerView; 
import com.github.mikephil.charting.data.CandleEntry; 
import com.github.mikephil.charting.data.Entry; 
import com.github.mikephil.charting.utils.Utils; 

/** 
* Custom implementation of the MarkerView. 
* 
* @author Philipp Jahoda 
*/ 
public class MyMarkerView extends MarkerView { 

    private TextView tvContent; 

    public MyMarkerView(Context context, int layoutResource) { 
     super(context, layoutResource); 

     tvContent = (TextView) findViewById(R.id.tvContent); 
    } 

    // callbacks everytime the MarkerView is redrawn, can be used to update the 
    // content (user-interface) 
    @Override 
    public void refreshContent(Entry e, int dataSetIndex) { 

     if (e instanceof CandleEntry) { 

      CandleEntry ce = (CandleEntry) e; 

      tvContent.setText("" + Utils.formatNumber(ce.getHigh(), 0, true)); 
     } else { 

      tvContent.setText("" + Utils.formatNumber(e.getVal(), 0, true)); 
     } 
    } 

    @Override 
    public int getXOffset() { 
     // this will center the marker-view horizontally 
     return -(getWidth()/2); 
    } 

    @Override 
    public int getYOffset() { 
     // this will cause the marker-view to be above the selected value 
     return -getHeight(); 
    } 
} 

Và trong Fragment Class, Thêm

 MyMarkerView mv = new MyMarkerView(this.getActivity(), R.layout.custom_marker_view); 

     // set the marker to the chart 
     mChart.setMarkerView(mv); 

thể này hữu ích cho bạn ..

Các vấn đề liên quan