仅将Google实时图形上的Stick Y轴放在一个位置

问题描述 投票:1回答:1

我正在将webview的google chart / graph用于我的iOS / Objective c代码。但是我拥有的数据太长了,因此就所有值而言它都在滚动。但是Y轴也会随着数据滚动,因此后面的值很难识别。有什么办法可以使Y轴成为静态的,而无论x轴上的值有多长,它都不会滚动。在这里提出一个建议后,我尝试使用范围过滤器,但是该html在Web浏览器上有效,但是我无法在iPhone设备上单击过滤器范围。

下面是示例HTML

<!DOCTYPE html>
<html>
    <head>
        <script src="https://www.gstatic.com/charts/loader.js"></script>

        <script type="text/javascript">
            google.load('visualization', '1', {packages: ['controls']});
            google.charts.load('current', {'packages':['line']});
            google.charts.setOnLoadCallback(drawChart);
            function drawChart() {

                var data = new google.visualization.DataTable();
                data.addColumn('datetime', 'date');
                data.addColumn('number', 'foo');
                data.addRows([
                              [new Date(2019,9,01,00,00,02),31.620001],
                              [new Date(2019,9,01,01,00,28),31.520000],
                              [new Date(2019,9,01,02,00,22),30.320000],
                              [new Date(2019,9,01,03,00,18),31.200001],
                              [new Date(2019,9,01,04,00,18),29.500000],
                              [new Date(2019,9,01,05,00,14),27.500000],
                              [new Date(2019,9,01,06,00,40),27.059999],
                              [new Date(2019,9,01,07,00,05),26.750000],
                              [new Date(2019,9,01,08,00,05),26.070000],
                              [new Date(2019,9,01,09,00,24),25.750000],
                              [new Date(2019,9,01,10,00,49),25.299999],
                              [new Date(2019,9,01,11,00,14),24.129999],
                              [new Date(2019,9,01,12,03,15),22.379999],
                              [new Date(2019,9,01,13,00,29),21.980000],
                              [new Date(2019,9,01,14,01,24),21.820000],
                              [new Date(2019,9,01,15,02,52),21.250000],
                              [new Date(2019,9,01,16,00,08),19.450001],
                              [new Date(2019,9,01,17,00,06),18.879999],
                              [new Date(2019,9,01,18,00,30),18.660000],
                              [new Date(2019,9,01,19,00,23),17.910000],
                              [new Date(2019,9,01,20,01,51),17.040001],
                              [new Date(2019,9,01,21,00,14),16.430000],
                              [new Date(2019,9,01,22,01,08),16.730000],
                              [new Date(2019,9,01,23,00,30),16.450001],
                              [new Date(2019,9,02,00,00,23),16.400000],
                              [new Date(2019,9,02,01,00,15),16.080000],
                              [new Date(2019,9,02,02,00,41),15.300000],
                              [new Date(2019,9,02,03,00,36),14.540000],
                              [new Date(2019,9,02,04,00,00),13.970000],
                              [new Date(2019,9,02,05,00,24),13.650000],
                              [new Date(2019,9,02,06,01,20),13.160000],
                              [new Date(2019,9,02,07,00,09),12.710000],
                              [new Date(2019,9,02,08,02,08),12.650000],
                              [new Date(2019,9,02,09,00,22),12.660000],
                              [new Date(2019,9,02,10,00,18),12.420000],
                              [new Date(2019,9,02,11,00,09),12.470000],
                              [new Date(2019,9,02,12,00,39),12.350000],
                              [new Date(2019,9,02,13,00,31),12.180000],
                              [new Date(2019,9,02,14,00,25),11.880000],
                              [new Date(2019,9,02,15,00,25),11.680000],
                              [new Date(2019,9,02,16,01,21),11.430000],
                              [new Date(2019,9,02,17,00,39),10.770000],
                              [new Date(2019,9,02,18,00,38),10.200000],
                              [new Date(2019,9,02,19,00,01),10.820000],
                              [new Date(2019,9,02,20,02,02),11.490000],
                              [new Date(2019,9,02,21,00,22),12.670000],
                              [new Date(2019,9,02,22,00,15),12.870000],
                              [new Date(2019,9,02,23,00,11),12.660000],
                              [new Date(2019,9,03,00,00,37),12.710000],
                              [new Date(2019,9,03,01,00,01),11.730000],
                              [new Date(2019,9,03,02,01,27),11.310000],
                              [new Date(2019,9,03,03,00,49),11.010000],
                              [new Date(2019,9,03,04,00,10),10.550000],
                              [new Date(2019,9,03,05,00,04),9.910000],
                              [new Date(2019,9,03,06,01,01),9.690000],
                              [new Date(2019,9,03,07,00,24),9.540000],
                              [new Date(2019,9,03,08,02,22),9.330000],
                              [new Date(2019,9,03,09,00,09),9.210000],
                              [new Date(2019,9,03,10,01,02),9.210000],
                              [new Date(2019,9,03,11,01,27),9.230000],
                              [new Date(2019,9,03,12,00,45),9.340000],
                              [new Date(2019,9,03,13,00,38),9.390000],
                              [new Date(2019,9,03,14,12,35),9.530000],
                              [new Date(2019,9,03,15,02,55),9.490000],
                              [new Date(2019,9,03,16,02,18),9.620000],
                              [new Date(2019,9,03,17,00,03),9.780000],
                              [new Date(2019,9,03,18,00,01),9.630000],
                              [new Date(2019,9,03,19,00,58),9.810000],
                              [new Date(2019,9,03,20,00,20),10.200000],
                              [new Date(2019,9,03,21,00,47),10.910000],
                              [new Date(2019,9,03,22,00,12),11.890000],
                              [new Date(2019,9,03,23,00,10),12.260000],
                              [new Date(2019,9,04,00,00,06),12.920000],
                              [new Date(2019,9,04,01,00,39),14.690000],
                              [new Date(2019,9,04,02,00,29),12.840000],
                              [new Date(2019,9,04,03,00,23),12.830000],
                              [new Date(2019,9,04,04,00,19),10.750000],
                              [new Date(2019,9,04,05,00,18),9.530000],
                              [new Date(2019,9,04,06,03,46),9.050000],
                              [new Date(2019,9,04,07,01,01),8.870000],
                              [new Date(2019,9,04,08,01,23),8.650000],
                              [new Date(2019,9,04,09,00,45),8.480000],
                              [new Date(2019,9,04,10,00,04),8.090000],
                              [new Date(2019,9,04,11,01,31),7.930000],
                              [new Date(2019,9,04,12,02,58),7.790000],
                              [new Date(2019,9,04,13,01,17),7.630000],
                              [new Date(2019,9,04,14,01,39),7.630000],
                              [new Date(2019,9,04,15,02,36),7.540000],
                              [new Date(2019,9,04,16,04,31),7.470000],
                              [new Date(2019,9,04,17,00,12),7.480000],
                              [new Date(2019,9,04,18,08,27),7.790000],
                              [new Date(2019,9,04,19,02,32),6.420000],
                              [new Date(2019,9,04,20,00,49),8.860000],
                              [new Date(2019,9,04,21,01,45),9.530000],
                              [new Date(2019,9,04,22,01,39),9.980000],
                              [new Date(2019,9,04,23,00,01),10.190000],
                              [new Date(2019,9,05,00,00,57),10.430000],
                              [new Date(2019,9,05,01,00,20),11.670000],
                              [new Date(2019,9,05,02,01,19),11.540000],
                              [new Date(2019,9,05,03,01,42),11.130000],
                              [new Date(2019,9,05,04,02,39),10.350000],
                              [new Date(2019,9,05,05,10,22),9.460000],
                              [new Date(2019,9,05,06,01,20),9.110000],
                              [new Date(2019,9,05,07,01,11),8.770000],
                              [new Date(2019,9,05,08,00,32),7.920000],
                              [new Date(2019,9,05,09,03,41),6.630000],
                              [new Date(2019,9,05,10,01,21),7.200000],
                              [new Date(2019,9,05,11,01,44),8.100000],
                              [new Date(2019,9,05,12,00,01),8.640000],
                              [new Date(2019,9,05,13,00,59),8.710000],
                              [new Date(2019,9,05,14,00,23),8.900000],
                              [new Date(2019,9,05,15,00,21),8.760000],
                              [new Date(2019,9,05,16,00,18),8.420000],
                              [new Date(2019,9,05,17,01,49),8.320000],
                              [new Date(2019,9,05,18,00,06),8.510000],
                              [new Date(2019,9,05,19,00,39),8.910000],
                              [new Date(2019,9,05,20,01,06),9.190000],
                              [new Date(2019,9,05,21,00,29),9.150000],
                              [new Date(2019,9,05,22,00,26),9.220000],
                              [new Date(2019,9,05,23,00,19),9.950000],
                              [new Date(2019,9,06,00,00,09),10.580000],
                              [new Date(2019,9,06,01,00,05),10.940000],
                              [new Date(2019,9,06,02,01,04),11.210000],
                              [new Date(2019,9,06,03,00,59),11.390000],
                              [new Date(2019,9,06,04,00,23),11.630000],
                              [new Date(2019,9,06,05,01,21),12.070000],
                              [new Date(2019,9,06,06,00,13),12.340000],
                              [new Date(2019,9,06,07,00,12),11.790000],
                              [new Date(2019,9,06,08,00,16),11.000000],
                              [new Date(2019,9,06,09,00,05),10.610000],
                              [new Date(2019,9,06,10,01,36),10.140000],
                              [new Date(2019,9,06,11,00,57),9.760000],
                              [new Date(2019,9,06,12,00,20),8.820000],
                              [new Date(2019,9,06,13,01,18),7.010000],
                              [new Date(2019,9,06,14,02,16),8.120000],
                              [new Date(2019,9,06,15,01,05),6.340000],
                              [new Date(2019,9,06,16,01,26),5.000000],
                              [new Date(2019,9,06,17,03,26),5.580000],
                              [new Date(2019,9,06,18,00,09),7.920000],
                              [new Date(2019,9,06,19,00,34),10.000000],
                              [new Date(2019,9,06,20,00,00),12.890000],
                              [new Date(2019,9,06,21,00,27),16.360001],
                              [new Date(2019,9,06,22,00,19),19.139999],
                              [new Date(2019,9,06,23,00,45),20.250000],
                              [new Date(2019,9,07,00,00,09),20.540001],
                              [new Date(2019,9,07,01,00,04),20.790001],
                              [new Date(2019,9,07,02,00,00),20.129999],
                              [new Date(2019,9,07,03,00,26),18.990000],
                              [new Date(2019,9,07,04,00,18),17.290001],
                              [new Date(2019,9,07,05,01,48),11.430000],
                              [new Date(2019,9,07,06,01,40),8.740000],
                              [new Date(2019,9,07,07,03,37),7.340000],
                              [new Date(2019,9,07,08,01,55),6.340000],
                              [new Date(2019,9,07,09,00,23),6.080000],
                              [new Date(2019,9,07,10,00,05),5.930000],
                              [new Date(2019,9,07,11,01,29),7.650000],
                              [new Date(2019,9,07,12,02,26),9.430000],
                              [new Date(2019,9,07,13,00,46),10.850000],
                              [new Date(2019,9,07,14,01,41),7.600000],
                              [new Date(2019,9,07,15,02,05),5.810000],
                              [new Date(2019,9,07,16,03,36),5.170000],
                              [new Date(2019,9,07,17,02,55),4.680000],
                              [new Date(2019,9,07,18,01,42),5.880000],
                              [new Date(2019,9,07,19,00,03),9.330000],
                              [new Date(2019,9,07,20,00,27),12.350000],
                              [new Date(2019,9,07,21,00,21),17.629999],
                              [new Date(2019,9,07,22,00,17),19.809999],
                              [new Date(2019,9,07,23,00,49),20.990000],
                              [new Date(2019,9,08,00,00,05),21.440001],
                              [new Date(2019,9,08,01,01,06),21.709999],
                              [new Date(2019,9,08,02,01,11),21.650000],
                              [new Date(2019,9,08,03,00,58),21.110001],
                              [new Date(2019,9,08,04,00,24),16.690001],
                              [new Date(2019,9,08,05,01,17),10.490000],
                              [new Date(2019,9,08,06,06,54),7.880000],
                              [new Date(2019,9,08,07,05,44),6.410000],
                              [new Date(2019,9,08,08,03,08),5.460000],
                              [new Date(2019,9,08,09,03,39),4.560000],
                              [new Date(2019,9,08,10,02,49),3.980000],
                              [new Date(2019,9,08,11,02,30),3.490000],
                              [new Date(2019,9,08,12,02,21),3.120000],
                              [new Date(2019,9,08,13,02,11),2.800000],
                              [new Date(2019,9,08,14,02,02),2.590000],
                              [new Date(2019,9,08,15,01,53),2.310000],
                              [new Date(2019,9,08,16,00,41),2.190000],
                              [new Date(2019,9,08,17,00,33),2.150000],
                              [new Date(2019,9,08,18,00,55),2.580000],
                              [new Date(2019,9,08,19,06,02),7.060000],
                              [new Date(2019,9,08,20,01,10),12.310000],
                              [new Date(2019,9,08,21,00,01),18.440001],
                              [new Date(2019,9,08,22,00,59),21.549999],
                              [new Date(2019,9,08,23,00,22),22.700001],
                              [new Date(2019,9,09,00,00,23),22.719999],
                              [new Date(2019,9,09,01,00,11),23.030001],
                              [new Date(2019,9,09,02,00,06),22.350000],
                              [new Date(2019,9,09,03,00,35),21.850000],
                              [new Date(2019,9,09,04,00,27),18.879999],
                              [new Date(2019,9,09,05,03,54),14.700000],
                              [new Date(2019,9,09,06,01,14),13.720000],
                              [new Date(2019,9,09,07,02,45),13.350000],
                              [new Date(2019,9,09,08,03,07),12.850000],
                              [new Date(2019,9,09,09,01,57),10.910000],
                              [new Date(2019,9,09,10,00,13),10.550000],
                              [new Date(2019,9,09,11,01,10),11.270000],
                              [new Date(2019,9,09,12,01,36),11.140000],
                              [new Date(2019,9,09,13,00,24),10.550000],
                              [new Date(2019,9,09,14,00,16),10.080000],
                              [new Date(2019,9,09,15,05,26),8.450000],
                              [new Date(2019,9,09,16,00,42),7.790000],
                              [new Date(2019,9,09,17,01,01),9.820000],
                              [new Date(2019,9,09,18,00,56),10.790000],
                              [new Date(2019,9,09,19,00,19),12.400000],
                              [new Date(2019,9,09,20,01,52),14.790000],
                              [new Date(2019,9,09,21,00,15),19.910000],
                              [new Date(2019,9,09,22,00,09),21.860001],
                              [new Date(2019,9,09,23,00,10),22.730000],
                              [new Date(2019,9,10,00,00,01),23.030001],
                              [new Date(2019,9,10,01,00,58),22.480000],
                              [new Date(2019,9,10,02,00,22),21.540001],
                              [new Date(2019,9,10,03,00,18),19.629999],
                              [new Date(2019,9,10,04,00,15),17.709999],
                              [new Date(2019,9,10,05,00,40),16.340000],
                              [new Date(2019,9,10,06,01,07),15.160000],
                              [new Date(2019,9,10,07,00,25),13.740000],
                              [new Date(2019,9,10,08,01,55),12.880000],
                              [new Date(2019,9,10,09,02,49),12.800000],
                              [new Date(2019,9,10,10,01,04),13.770000],
                              [new Date(2019,9,10,11,00,30),14.920000],
                              [new Date(2019,9,10,12,00,21),14.450000],
                              [new Date(2019,9,10,13,00,16),12.480000],
                              [new Date(2019,9,10,14,00,38),11.640000],
                              [new Date(2019,9,10,15,02,37),11.520000],
                              [new Date(2019,9,10,16,02,27),11.540000],
                              [new Date(2019,9,10,17,10,41),11.010000],
                              [new Date(2019,9,10,18,08,27),11.180000],
                              [new Date(2019,9,10,19,03,45),12.890000],
                              [new Date(2019,9,10,20,01,54),13.860000],
                              [new Date(2019,9,10,21,00,16),15.320000],
                              [new Date(2019,9,10,22,00,45),17.530001],
                              [new Date(2019,9,10,23,00,08),17.340000],
                              [new Date(2019,9,11,00,00,04),17.270000],
                              [new Date(2019,9,11,01,00,00),17.230000],
                              [new Date(2019,9,11,02,00,27),17.160000],
                              [new Date(2019,9,11,03,00,21),17.559999],
                              [new Date(2019,9,11,04,00,17),17.690001],
                              [new Date(2019,9,11,05,00,47),17.670000],
                              [new Date(2019,9,11,06,00,09),17.320000],
                              [new Date(2019,9,11,07,00,11),16.680000],
                              [new Date(2019,9,11,08,00,08),16.330000],
                              [new Date(2019,9,11,09,02,11),16.420000],
                              [new Date(2019,9,11,10,00,25),16.530001],
                              [new Date(2019,9,11,11,00,23),16.690001],
                              [new Date(2019,9,11,12,00,19),16.670000],
                              [new Date(2019,9,11,13,00,17),13.160000],
                              [new Date(2019,9,11,14,00,12),8.250000],
                              [new Date(2019,9,11,15,00,40),6.010000],
                              [new Date(2019,9,11,16,00,02),5.110000],
                              [new Date(2019,9,11,17,00,32),4.400000],
                              [new Date(2019,9,11,18,00,27),4.030000],
                              [new Date(2019,9,11,19,00,48),4.340000],
                              [new Date(2019,9,11,20,00,11),4.200000],
                              [new Date(2019,9,11,21,00,08),4.550000],
                              [new Date(2019,9,11,22,01,02),4.690000],
                              [new Date(2019,9,11,23,00,22),4.900000],
                              [new Date(2019,9,12,00,00,20),4.850000],
                              [new Date(2019,9,12,01,00,17),4.420000],
                              [new Date(2019,9,12,02,00,42),4.230000],
                              [new Date(2019,9,12,03,00,04),3.850000]
                              ]);
                              var rangeFilter = new google.visualization.ControlWrapper({
                            controlType: 'ChartRangeFilter',
                            containerId: 'range_filter_div',
                            options: {
                            filterColumnIndex: 0,
                            ui: {
                            chartOptions: {
                            height: 50,
                            width: 350,
                            chartArea: {
                            width: '75%'
                            }
                            },
                            minRangeSize: 864000, // 86400000ms = 1 day
                            snapToData: true
                            }
                            },
                            view: {
                            columns: [0, 1]
                            },
                            state: {
                            range: {
                            // set the starting range to January 2012
                            start: new Date(2019, 9, 1),
                            end: new Date(2019, 9, 10)
                            }
                            }
                            });


                              var chart = new google.visualization.ChartWrapper({
                                                                                chartType: 'LineChart',
                                                                                containerId: 'chart_div',
                                                                                options: {
                                                                                // width and chartArea.width should be the same for the filter and chart
                                                                                height: 300,
                                                                                width: 400,
                                                                                chartArea: {
                                                                                width: '75%'
                                                                                },legend: 'none',
                                                                                colors: ['#19acc6', '#19acc6'],
                                                                                width: 350,
                                                                                height: 500,
                                                                                options: {
                                                                                theme: 'maximized'
                                                                                },
                                                                                interpolateNulls: true,
                                                                                hAxis: {
                                                                                format: 'E, d-MMM'
                                                                                },
                                                                                vAxis: {
                                                                                format:'#°'
                                                                                },
                                                                                'backgroundColor': 'transparent',
                                                                                }
                                                                                });

                                                                                // Create the dashboard
                                                                                var dash = new google.visualization.Dashboard(document.getElementById('dashboard'));
                                                                                // bind the chart to the filter
                                                                                dash.bind([rangeFilter], [chart]);
                                                                                // draw the dashboard
                                                                                dash.draw(data);


            }
        </script>
    </head>
    <body>
        <div id="line_top_x"></div>
        <div id="dashboard">
            <div id="chart_div"></div>
            <div id="range_filter_div"></div>
        </div>
    </body>
</html>
ios objective-c graph google-visualization google-chartwrapper
1个回答
0
投票

我以某种方式找到了解决方案,事实是您无法在Google图形中做任何事情来粘住y轴,并且范围过滤器在移动视图中也不起作用,因此在这里也将不起作用。

所以我所做的就是添加了一个具有相同值的WebView,并且启用了用户交互,否,当第一个Webview滚动25个像素时,我将其更改为帧并将第二个Webview属性设置为No,因此y轴将始终存在,但是将是另一个具有相同值的webview。

 NSString *htmlFile = [[NSBundle mainBundle] pathForResource:@"graph1" ofType:@"html"];
        NSString* htmlString = [NSString stringWithContentsOfFile:htmlFile encoding:NSUTF8StringEncoding error:nil];
        webV=[[UIWebView alloc]initWithFrame:CGRectMake(0, 100, self.view.frame.size.width-100, self.view.frame.size.height-40)];
        webV.delegate=self;
        webV.scrollView.delegate=self;
        [webV loadHTMLString:htmlString baseURL:[[NSBundle mainBundle] bundleURL]];

        NSString *htmlFile2 = [[NSBundle mainBundle] pathForResource:@"graph1" ofType:@"html"];
        NSString* htmlString2 = [NSString stringWithContentsOfFile:htmlFile2 encoding:NSUTF8StringEncoding error:nil];
       webV2=[[UIWebView alloc]initWithFrame:CGRectMake(0, 100, self.view.frame.size.width, self.view.frame.size.height-100)];
        webV2.delegate=self;
        [webV2 loadHTMLString:htmlString2 baseURL:[[NSBundle mainBundle] bundleURL]];
        [self.view addSubview:webV2];
        [self.view addSubview:webV];
        [webV2 setHidden:YES];
        [webV2 setUserInteractionEnabled:YES];
        [webV setUserInteractionEnabled:YES];
        [webV2 setUserInteractionEnabled:NO];
        [self.view setBackgroundColor:[UIColor whiteColor]];
        [webV2 setBackgroundColor:[UIColor whiteColor]];
        [webV setBackgroundColor:[UIColor whiteColor]];
        webV2.scrollView.alwaysBounceVertical=NO;




-(void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
    if (scrollView.contentOffset.x>30) {
        [webV2 setHidden:NO];
        webV.frame=CGRectMake(30, 100, self.view.frame.size.width-30, self.view.frame.size.height-100);
    }
    else
    {
        [webV2 setHidden:YES];
        webV.frame=CGRectMake(0, 100, self.view.frame.size.width-30, self.view.frame.size.height-100);
    }
    webV2.userInteractionEnabled=YES;
    webV.userInteractionEnabled=YES;

    NSLog(@"%@",NSStringFromCGPoint(scrollView.contentOffset));

}

-(void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    if (scrollView.contentOffset.x>30) {
        [webV2 setHidden:NO];
        webV.frame=CGRectMake(30, 100, self.view.frame.size.width-30, self.view.frame.size.height-100);
    }
    else
    {
        [webV2 setHidden:YES];
        webV.frame=CGRectMake(0, 100, self.view.frame.size.width-30, self.view.frame.size.height-100);
    }
//    if (scrollView.contentOffset.y > 0)
//    scrollView.contentOffset = CGPointMake(scrollView.contentOffset.x, 0);

}
© www.soinside.com 2019 - 2024. All rights reserved.