开发者

compose sms task in windows phone 7 c#

开发者 https://www.devze.com 2023-03-24 23:16 出处:网络
I am trying to do a composeSMS task in windows phone 7. And i have a array of data retrieve from isolated storage.

I am trying to do a composeSMS task in windows phone 7. And i have a array of data retrieve from isolated storage. How can i make it loop to get all the data into one message. Below is my code but it only get the lastest data.

开发者_开发技巧private void sendSmsBtn_Click(object sender, RoutedEventArgs e)
{
    try
    {
        //For sorted time
        StreamReader readFileTime = new StreamReader(new IsolatedStorageFileStream(fullFolderName + "\\time.Schedule", FileMode.Open, myStore));

        //For time
        StreamReader readFileTime1 = new StreamReader(new IsolatedStorageFileStream(fullFolderName + "\\time1.Schedule", FileMode.Open, myStore));

        //For title
        StreamReader readFileTitle = new StreamReader(new IsolatedStorageFileStream(fullFolderName + "\\title.Schedule", FileMode.Open, myStore));

        //For category
        StreamReader readFileCategory = new StreamReader(new IsolatedStorageFileStream(fullFolderName + "\\category.Schedule", FileMode.Open, myStore));


        //Sorted time list
        String timeText = readFileTime.ReadLine();
        timeSplit = timeText.Split(new char[] { '^' });
            Array.Sort(timeSplit, delegate(string first, string second)
        {
            return DateTime.Compare(Convert.ToDateTime(first), Convert.ToDateTime(second));
        });


        String timeText1 = readFileTime1.ReadLine();

        timeSplit1 = timeText1.Split(new char[] { '^' });
        //Array.Sort(timeSplit1);

        String titleText = readFileTitle.ReadLine();
        titleSplit = titleText.Split(new char[] { '^' });
        Array.Sort(titleSplit);

        String categoryText = readFileCategory.ReadLine();
        categorySplit = categoryText.Split(new char[] { '^' });
        Array.Sort(categorySplit);
    }

    catch (Exception)
    {
    }



    SmsComposeTask composeSMS = new SmsComposeTask();

        for (int i = 0; i < timeSplit.Length; i++)
        {
            timeList = timeSplit[i];
            titleList = titleSplit[i];
            categoryList = categorySplit[i];


            composeSMS.Body = "Below is my schedule: \n" +
                              "Date: " + timeList + "\n" +
                              "Time: " + titleList + "\n" +
                              "End time: " + categoryList + "\n";

        }
        composeSMS.Show();
}


TL;DR: You are constantly setting the message body in the loop instead of appending data to it. For it to work, you need to have:

composeSMS.Body += "Below is my schedule: \n" +
                 "Date: " + timeList + "\n" +
                 "Time: " + titleList + "\n" +
                 "End time: " + categoryList + "\n";

Now, let me point out that your code is not optimized and can generally be shortened. For example, look at this:

private void sendSmsBtn_Click(object sender, RoutedEventArgs e)
{
    try
    {
        StreamReader reader;
        string[] timeSplit;
        string[] timeSplit1;
        string[] titleSplit;
        string placeholder;
        string[] categorySplit;

        //For sorted time
        using (reader = new StreamReader(new IsolatedStorageFileStream(fullFolderName + "\\time.Schedule", FileMode.Open, myStore))
        {
            placeholder = reader.ReadLine();
        }
        timeSplit = placeholder.Split(new char[] { '^' });
        Array.Sort(timeSplit, delegate(string first, string second)
        {
           return DateTime.Compare(Convert.ToDateTime(first), Convert.ToDateTime(second)); 
        }); 

        using (reader = new StreamReader(new IsolatedStorageFileStream(fullFolderName + "\\time1.Schedule", FileMode.Open, myStore))
        {
            placeholder = reader.ReadLine();
        }
        timeSplit1 = placeholder.Split(new char[] { '^' });
        Array.Sort(titleSplit1);

        using (reader = new StreamReader(new IsolatedStorageFileStream(fullFolderName + "\\title.Schedule", FileMode.Open, myStore)))
        {
            placeholder = reader.ReadLine();
        }
        titleSplit = placeholder.Split(new char[] { '^' });
        Array.Sort(titleSplit);

        using(reader = new StreamReader(new IsolatedStorageFileStream(fullFolderName + "\\category.Schedule", FileMode.Open, myStore)))
        {
            placeholder = readFileCategory.ReadLine();
        }

        categorySplit = placeholder.Split(new char[] { '^' });
        Array.Sort(categorySplit);
    }

    catch (Exception)
    {
    }

    var composeSMS = new SmsComposeTask();
    var sBuilder = new StringBuilder();
    sBuilder.AppendLine("Below is my schedule:");

    for (int i = 0; i < timeSplit.Length; i++)
    {
        sBuilder.AppendLine("Date: " + timeSplit[i]);
        sBuilder.AppendLine("Time: " + titleSplit[i]);
        sBuilder.AppendLine("End time: " + categorySplit[i]);
    }

    composeSMS.Body = sBuilder.ToString();
    composeSMS.Show();
}

NOTE: I edited your code in Notepad without having access to a compiler. Some modifications might be needed.

Here are some major differences from what you have.

  • I am re-using the same reader (instance of StreamReader) over and over instead of creating new instances for every single file.
  • Notice the using statement used along the lines where the reader is used. Also notice curly braces - that way, the reader instance will be properly disposed once I am done working with it (reading a file).
  • You only need one instance of a placeholder string, since all composite line strings are never used anywhere. That placeholder string is reset with every read.
  • I am using a StringBuilder to build the body and only when it's ready, I am setting the Body property.
  • No need for intermediary variables inside the loop.

Last but not least - a very important advice. You need to refactor the way you are storing data. Reading four files in this case to build a single entity is wrong and resource-consuming. Consider using a single well-structured format (e.g. XML or JSON) to store the data in a single file. Even better, consider using a database (starting SDK v.7.1 there is support for SQL CE).

0

精彩评论

暂无评论...
验证码 换一张
取 消