Também encontrei o problema e encontrei o caminho para definir estilo por meio de programação. Talvez todos vocês precisem, então eu atualizo lá.
O terceiro parâmetro do construtor View aceita um tipo de atributo no seu tema como o código-fonte abaixo:
public TextView(Context context, AttributeSet attrs) {
this(context, attrs, com.android.internal.R.attr.textViewStyle);
}
Portanto, você deve passar um tipo de R.attr. ** em vez de R.style. **
Nos meus códigos, executei as seguintes etapas:
Primeiro, personalize um atributo personalizado para ser usado pelos temas em attr.xml.
<attr name="radio_button_style" format="reference" />
Segundo, especifique seu estilo no tema usado em 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>
No final, use-o!
RadioButton radioButton = new RadioButton(mContext, null, R.attr.radio_button_style);
a visualização criada programaticamente usará o estilo especificado no seu tema.
Você pode tentar e espero que funcione perfeitamente para você.