Spotkałem ten problem i znalazłem sposób na programowe ustawienie stylu. Może wszyscy tego potrzebujesz, więc aktualizuję.
Trzeci parametr konstruktora View akceptuje typ atrybutu w twoim motywie jako kod źródłowy poniżej:
public TextView(Context context, AttributeSet attrs) {
this(context, attrs, com.android.internal.R.attr.textViewStyle);
}
Musisz więc przekazać rodzaj R.attr. ** zamiast R. style. **
W moich kodach wykonałem następujące kroki:
Najpierw dostosuj niestandardowy plik attr do użycia przez kompozycje w pliku attr.xml.
<attr name="radio_button_style" format="reference" />
Po drugie, określ swój styl w używanym motywie w style.xml.
<style name="AppTheme" parent="android:Theme.Translucent">
<!-- All customizations that are NOT specific to a particular API-level can go here. -->
<item name="radio_button_style">@style/radioButtonStyle</item>
</style>
<style name="radioButtonStyle" parent="@android:style/Widget.CompoundButton.RadioButton">
<item name="android:layout_width">wrap_content</item>
<item name="android:layout_height">64dp</item>
<item name="android:background">#000</item>
<item name="android:button">@null</item>
<item name="android:gravity">center</item>
<item name="android:saveEnabled">false</item>
<item name="android:textColor">@drawable/option_text_color</item>
<item name="android:textSize">9sp</item>
</style>
Na koniec użyj go!
RadioButton radioButton = new RadioButton(mContext, null, R.attr.radio_button_style);
widok utworzony programowo użyje określonego stylu w twoim motywie.
Możesz spróbować i mam nadzieję, że będzie on dla Ciebie idealny.