Click here to Skip to main content
Licence CPOL
First Posted 22 Mar 2008
Views 11,513
Downloads 141
Bookmarked 13 times

Dynamic User Settings

By | 22 Mar 2008 | Article
Dynamic User Settings
Visual Studio makes it easy to add user and application scoped settings. The settings tab on your project properties will let you add settings at design time. You can decide the type, scope, and default value. There may be times however when you would like to add a user scoped property at run time. I will demonstrate how to do this.

Adding the Property:

  1. Create an instance of System.Configuration.SettingsAttributeDictionary.
  2. Create an instance of System.Configuration.UserScopedSettingsAttribute.
  3. Add the System.Configuration.UserScopedSettingsAttribute object to the System.Configuration.SettingsAttributeDictionary.
  4. Create an instance of System.Configuration.SettingsProperty passing the System.Configuration.SettingsAttributeDictionary into the contructor as well as the property name, default value, and type.
  5. Add the System.Configuration.SettingsAttributeDictionary to the My.MySettings.Default.Properties collection.

Example Code:

Private Sub AddProperty(ByVal propertyName As String, _
      ByVal defaultValue As String, ByVal propertyType As Type)
     Dim providerName As String = "LocalFileSettingsProvider"

     Dim attributes As New Configuration.SettingsAttributeDictionary()
     Dim attr As New Configuration.UserScopedSettingAttribute()
     attributes.Add(attr.TypeId(), attr)

     Dim prop As New Configuration.SettingsProperty( _
      New Configuration.SettingsProperty(propertyName, propertyType, _
     My.MySettings.Default.Providers(providerName), False, defaultValue, _
     Configuration.SettingsSerializeAs.String, attributes, False, False))

     My.MySettings.Default.Properties.Add(prop)
End Sub

Setting the Property Value:
Example Code:

My.MySettings.Default.Item(propertyName) = propertyValue
Getting the Property Value:

Example Code:

My.MySettings.Default.Item(propertyName).ToString()
Accessing the Property at Next Run:

You may notice that next time you run your application that the properties you added were not loaded automatically. Only properties that exist in your My.MySettings.Default object are loaded when properties are loaded.

  1. Add your property.
  2. Reload your My.MySettings.Default object.

Example Code:

AddProperty(SavedPropertyNameTextBox.Text, String.Empty)
My.MySettings.Default.Reload()


License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

About the Author

Guster_Q

Software Developer

United States United States

Member



Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
You must Sign In to use this message board. (secure sign-in)
 
Search this forum  
 FAQ
    Noise  Layout  Per page   
  Refresh
GeneralGreat Work!!! Pinmemberrajesh vasan4:07 29 Apr '10  
GeneralSource Missing confermed! PinmemberStrobe60009:51 9 Jan '09  
QuestionSource missing Pinmembersgaggerj2:32 16 May '08  

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

Permalink | Advertise | Privacy | Mobile
Web04 | 2.5.120517.1 | Last Updated 22 Mar 2008
Article Copyright 2008 by Guster_Q
Everything else Copyright © CodeProject, 1999-2012
Terms of Use
Layout: fixed | fluid