Question

J'ai un contrôle GridView où j'Aneed de montrer quelques informations concernant une variable importante de la mienne. Ces variables varient dans le temps et je voudrais tracer leur évolution dans le tableau comme la dernière colonne en utilisant un contrôle Chart.

Voici une vue générique du code:

<asp:GridView runat="server" ID="Variables_GridView" CssClass="grid" AutoGenerateColumns="false" Width="100%">
   <FooterStyle BackColor="White" ForeColor="#000066" />
   <HeaderStyle CssClass="gridheader" />
   <RowStyle ForeColor="#000066" />
   <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
   <SortedAscendingCellStyle BackColor="#F1F1F1" />
   <SortedAscendingHeaderStyle BackColor="#007DBB" />
   <SortedDescendingCellStyle BackColor="#CAC9C9" />
   <SortedDescendingHeaderStyle BackColor="#00547E" />
   <Columns>
      <asp:BoundField DataField="VariableName" HeaderText="Name" />
      <asp:BoundField DataField="VariableType" HeaderText="Type" />
      <asp:BoundField DataField="VariableDescription" HeaderText="Description" />
      <asp:TemplateField HeaderText="Latest values">
         <ItemTemplate>
            <asp:Chart ID="Values_Chart" runat="server" Width="150" Height="50">
               <Series>
                  <asp:Series Name="Values_Series" XAxisType="Primary" XValueType="Int32" ChartType="Line"></asp:Series>
               </Series>
               <ChartAreas>
                  <asp:ChartArea Name="Values_ChartArea"></asp:ChartArea>
               </ChartAreas>
            </asp:Chart>
         </ItemTemplate>
      </asp:TemplateField>
   </Columns>
</asp:GridView>

Dans mon codebehind vous pouvez trouver ce type, celui utilisé pour les propriétés de cartographie (ceux que je spécifiés):

public class VariableRepresentation {

        private string variableName;

        private string variableType;

        private string variableDescription;

        private float[] variableValues;

        public string VariableName {
            get { return this.variableName; }
            set { this.variableName = value; }
        }

        public string VariableType {
            get { return this.variableType; }
            set { this.variableType = value; }
        }

        public string VariableDescription {
            get { return this.variableDescription; }
            set { this.variableDescription = value; }
        }

        public float[] VariableValues {
            get { return this.variableValues; }
            set { this.variableValues = value; }
        }

        public VariableRepresentation(string name, string type, string description) {
            this.variableName = name;
            this.variableType = type;
            this.variableDescription = description;
        }

        public VariableRepresentation(string name, string type, string description, float[] initialValues) : this(name, type, description) {
            this.variableValues = initialValues;
        }

    }

OK!

Dans la méthode de chargement de cette page je suit:

protected void Page_Load(object sender, EventArgs e) {
   VariableRepresentation[] vars = new VariableRepresentation[6];
   vars[0] = new VariableRepresentation("Variable 1", 
      "Type 1", "A generic variable", new float[] { 11, 12, 13, 14, 11, 20 });
   vars[1] = new VariableRepresentation("Variable 2", 
      "Type 2", "A generic variable", new float[] { 11, 12, 13, 14, 11, 20 });
   vars[2] = new VariableRepresentation("Variable 3", 
      "Type 3", "A generic variable", new float[] { 11, 12, 13, 14, 11, 20 });
   vars[3] = new VariableRepresentation("Variable 4", 
      "Type 1", "A generic variable", new float[] { 11, 12, 13, 14, 11, 20 });
   vars[4] = new VariableRepresentation("Variable 5", 
      "Type 2", "A generic variable", new float[] { 11, 12, 13, 14, 11, 20 });
   vars[5] = new VariableRepresentation("Variable 6", 
      "Type 3", "A generic variable", new float[] { 11, 12, 13, 14, 11, 20 });
   this.Variables_GridView.DataSource = vars;
   this.Variables_GridView.DataBind();
}

Eh bien, comme vous pouvez l'imaginer, la sortie est une table, mais mon dossier est vide. Comment puis-je agir dans le fichier .aspx, dans le balisage xhtml, le premier code je l'ai montré, pour que cela se produise?

Je suppose que je shoild place dans le champ de modèle, des données liant l'expression, mais je ne sais pas quoi y placer ....

Pourriez-vous me aider s'il vous plaît?

Thankyou

PS: S'il vous plaît noter que je n'ai pas fourni une solution ici, la question est que je ne sais pas comment connecter les données au graphique, en fait il est exact que les cartes (une par ligne de table) rien show, parce que je n'ai pas précisé toutes les expressions de liaison dans la page ASPX ni correctement morceau de code dans codebehind.

Était-ce utile?

La solution

Je ne sais pas s'il y a un moyen pratique de la liaison de données en série graphique directement en XHTML? mais peut-être que vous pourriez créer un événement sur GridView.RowDataBound trouver le graphique, il contrôle puis ajouter les données à la série graphique?

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top